【发布时间】:2016-11-15 10:01:29
【问题描述】:
我必须说我对整个模型非常困惑,我需要帮助将所有浮动部分粘合在一起。
我没有做 Spring REST,只是简单的 WebMVC 控制器。
我的使命: 我想要一个带有用户名+通过身份验证的表单登录。我想针对 3rd 方服务进行身份验证。成功后我想返回一个 cookie 但不使用默认的 cookie 令牌机制。我希望 cookie 有一个 JWT 令牌。通过利用 cookie 机制,每个请求都将使用 JWT 发送。
因此,为了分解它,我需要处理以下模块:
- 在执行用户 + pas logi 时针对 3rd 方服务进行身份验证 n
验证成功后用我的自定义实现替换 cookie 会话令牌
在每次请求时从 cookie 中解析 JWT(使用过滤器)
从 JWT 中提取用户详细信息/数据以供控制器访问
什么令人困惑? (请指正我错的地方)
第三方认证
要针对第 3 方进行身份验证,我需要通过扩展 AuthenticationProvider 来获得自定义提供程序
public class JWTTokenAuthenticationProvider implements AuthenticationProvider {
@Override
public Authentication authenticate( Authentication authentication ) throws AuthenticationException {
// auth against 3rd party
// return Authentication
return new UsernamePasswordAuthenticationToken( name, password, new ArrayList<>() );
}
@Override
public boolean supports(Class<?> authentication) {
return authentication.equals( UsernamePasswordAuthenticationToken.class );
}
}
问题:
- 当用户提交表单用户+通过时,此提供程序是否在成功验证/登录时执行?如果是这样,那与 AbstractAuthenticationProcessingFilter#successfulAuthentication 有什么关系?
- 我必须返回一个 UsernamePasswordAuthenticationToken 的实例吗?
- 是否必须支持 UsernamePasswordAuthenticationToken 才能在此处获取用户 + 通行证?
用 JWT 替换 cookie 令牌
不知道如何优雅地做到这一点,我可以想到很多方法,但它们不是 Spring Security 的方法,我不想打破常规。非常感谢您在这里提出任何建议!
使用来自 cookie 的每个请求解析 JWT
据我了解,我需要像这样扩展 AbstractAuthenticationProcessingFilter
public class CookieAuthenticationFilter extends AbstractAuthenticationProcessingFilter {
@Override
public Authentication attemptAuthentication( HttpServletRequest request, HttpServletResponse response )
throws AuthenticationException, IOException, ServletException {
String token = "";
// get token from a Cookie
// create an instance to Authentication
TokenAuthentication authentication = new TokenAuthentication(null, null);
return getAuthenticationManager().authenticate(tokenAuthentication);
}
@Override
public void doFilter(ServletRequest req, ServletResponse res,
FilterChain chain) throws IOException, ServletException {
super.doFilter(req, res, chain);
}
}
问题:
- 何时调用 AbstractAuthenticationProcessingFilter#successfulAuthentication?是在用户登录时调用还是在成功验证 JWT 令牌时调用?
- 此过滤器与我之前发布的自定义提供程序之间是否有任何关系?经理应该会根据令牌实例调用自定义提供者,该令牌实例与提供者通过支持方法支持的内容相匹配?
似乎我拥有了我需要的所有部分,除了 cookie 会话替换,但我无法将它们放入一个连贯的模型中,我需要一个对机制足够了解的人,这样我就可以将所有这些整合到单个模块。
更新 1
此过滤器将自己注册到 POST -> "/login",然后创建一个 UsernamePasswordAuthenticationToken 实例并将控制权传递给下一个过滤器。
问题是设置 cookie 会话的位置......
更新 2
dos 的这一部分给出了我所缺少的顶级流程,任何正在经历这个的人都可以在这里查看...http://docs.spring.io/spring-security/site/docs/current/reference/htmlsingle/#tech-intro-authentication
本节关于 AuthenticationProvider...http://docs.spring.io/spring-security/site/docs/current/reference/htmlsingle/#core-services-authentication-manager
更新 3 - 工作案例,这是最好的方法吗?
因此,在深入研究了 Spring Security 文档及其源代码后,我得到了初始模型。现在,这样做,我意识到有不止一种方法可以做到这一点。关于为什么选择这种方式 VS Denys 下面提出的任何建议?
下面的工作示例...
【问题讨论】:
标签: java spring authentication spring-security