Spring认证成功后添加请求头
我有一个应用程序,其中 JWT 令牌的身份验证是使用 spring security 自定义过滤器完成的。配置如下所示,用于调用执行身份验证的客户过滤器。
<security:http entry-point-ref="authenticationEntryPoint">
<security:custom-filter after="BASIC_AUTH_FILTER" ref="TokenValidationFilter" />
<security:session-management>
<security:concurrency-control max-sessions="1" />
</security:session-management>
<security:csrf disabled="true"/>
<security:anonymous enabled="false"/>
</security:http>
我扩展了 AbstractAuthenticationProcessingFilter 类并实现了 TokenValidationFilter 并能够验证请求标头中收到的令牌。身份验证成功后,我想调用另一个外部 API 并获取一些值并将它们附加到当前请求标头中。 AbstractAuthenticationProcessingFilter 类提供 successAuthentication 方法作为回调,我可以在其中进行外部调用并修改请求标头。但我想要一个单独的类或过滤器,需要在成功验证代码可维护性后调用。请让我知道 Spring 是否为此提供了任何选项。我是 Spring 的新手,搜索了多个站点,但不知道如何解决这个问题。任何建议都会很有帮助。谢谢
I have an app where authentication of JWT token is done using spring security custom filter. The configuration looks as below to invoke the customer filter which does the authentication.
<security:http entry-point-ref="authenticationEntryPoint">
<security:custom-filter after="BASIC_AUTH_FILTER" ref="TokenValidationFilter" />
<security:session-management>
<security:concurrency-control max-sessions="1" />
</security:session-management>
<security:csrf disabled="true"/>
<security:anonymous enabled="false"/>
</security:http>
I extended AbstractAuthenticationProcessingFilter class and implemented TokenValidationFilter and able to authenticate the token received in request header. After successfull authentication, I want to call an another external API and get few values and append them in current request header. AbstractAuthenticationProcessingFilter class offers successfulAuthentication method as callback where I can do the external call and modify the request header. But I want to have a separate class or filter which needs to be invoked after successfull authentication for code maintainablility. Please let me know whether Spring offers any option for this. I am newbie to Spring and searched multiple sites but could not figure out how to approach this. Any suggestion would be much helpful.Thanks
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(1)
请查看
AuthenticationSuccessHandler
。它允许您控制登录成功时的响应。
这是一个例子:
Please look into
AuthenticationSuccessHandler
.It allows you to control the response when login is successful.
Here is an example: