【发布时间】:2023-03-27 05:20:01
【问题描述】:
我最近开始学习 Spring Security,今天我遇到了这个基本(我相信)问题:为什么我不能访问 Servlet 过滤器中的当前 Principal,如下面的课程所示:
package com.acme.test;
import java.io.IOException;
import javax.servlet.Filter;
import javax.servlet.FilterChain;
import javax.servlet.FilterConfig;
import javax.servlet.ServletException;
import javax.servlet.ServletRequest;
import javax.servlet.ServletResponse;
import org.springframework.security.core.Authentication;
import org.springframework.security.core.context.SecurityContext;
import org.springframework.security.core.context.SecurityContextHolder;
import org.springframework.stereotype.Component;
@Component
public class TestFilter implements Filter {
/*
* (non-Javadoc)
*
* @see javax.servlet.Filter#init(javax.servlet.FilterConfig)
*/
@Override
public void init(FilterConfig filterConfig) throws ServletException {
// TODO Auto-generated method stub
}
/*
* (non-Javadoc)
*
* @see javax.servlet.Filter#doFilter(javax.servlet.ServletRequest,
* javax.servlet.ServletResponse, javax.servlet.FilterChain)
*/
@Override
public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain)
throws IOException, ServletException {
SecurityContext securityContext = SecurityContextHolder.getContext();
Authentication auth = securityContext.getAuthentication();
// auth is null here
chain.doFilter(request, response);
}
/*
* (non-Javadoc)
*
* @see javax.servlet.Filter#destroy()
*/
@Override
public void destroy() {
// TODO Auto-generated method stub
}
}
使用 Authentication auth = securityContext.getAuthentication(); 检索到的 Authentication 对象为空。在 MVC @Controller 中使用上面的 sn-p 可以正常工作(如预期的那样)。
为什么会这样?
【问题讨论】:
-
我会查看 spring 安全过滤器链,以覆盖默认的 spring 配置并将过滤器插入到正确的位置。身份验证可能仅在特定位置可用docs.spring.io/spring-security/site/docs/3.1.x/reference/…
-
@jpprade 谢谢。我对通用过滤器最感兴趣,所以我不想覆盖安全过滤器。似乎(从下面的答案)配置过滤器的顺序是有效的。
标签: spring spring-mvc servlets spring-security