2 回答
data:image/s3,"s3://crabby-images/ee628/ee6280e02c49a32e693d76a2c62fb027d36689c1" alt="?"
TA贡献1828条经验 获得超4个赞
尝试添加sec:authorize="isAuthenticated()
到要显示用户名的“/account/login”模板
例如:
<h3 sec:authorize="isAuthenticated()" th:text="${user.username}"></h3>
如果它发生了,它将获得身份验证状态,否则,它不会显示<h3>
代码块。
data:image/s3,"s3://crabby-images/ec182/ec1829210f261145bb2e46345c51529c9edc3a93" alt="?"
TA贡献1982条经验 获得超2个赞
@Component
public class MyBasicAuthenticationEntryPoint extends BasicAuthenticationEntryPoint {
@Override
public void afterPropertiesSet() throws Exception {
setRealmName("Baeldung");
super.afterPropertiesSet();
}
@Override
public void commence(
HttpServletRequest request, HttpServletResponse response, AuthenticationException authEx)
throws IOException, ServletException {
response.addHeader("WWW-Authenticate", "Basic realm="" + getRealmName() + """);
response.setStatus(HttpServletResponse.SC_UNAUTHORIZED);
PrintWriter writer = response.getWriter();
writer.println("HTTP Status 401 - " + authEx.getMessage());
}
}
// inside filter we can get the
SecurityContextHolder.getContext().getAuthentication().getPrincipal()
添加回答
举报