欢迎访问 生活随笔!

生活随笔

当前位置: 首页 >

Spring Security 退出登录(7)

发布时间:2024/3/13 71 豆豆
生活随笔 收集整理的这篇文章主要介绍了 Spring Security 退出登录(7) 小编觉得挺不错的,现在分享给大家,帮大家做个参考.

Spring Security默认的退出登录URL为/logout,退出登录后,Spring Security会做如下处理:

  • 使当前的Sesion失效;
  • 清除与当前用户关联的RememberMe记录;
  • 清空当前的SecurityContext;
  • 重定向到登录页。
  • Spring Security允许我们通过配置来更改上面这些默认行为。

    1. 自定义退出登录行为

    我们在Spring Security配置中添加如下配置:

    ...... .and().logout().logoutUrl("/signout").logoutSuccessUrl("/signout/success").deleteCookies("JSESSIONID") .and() ......

    上面配置了退出登录的URL为/signout,退出成功后跳转的URL为/signout/success,退出成功后删除名称为JSESSIONID的cookie。

    在Controller中添加和/signout/success对应的方法:

    @GetMapping("/signout/success") public String signout() {return "退出成功,请重新登录"; }

    接着将/signout/success添加到免认证路径里。启动项目,登录后访问/signout:

    可看到退出成功,并且请求重定向到了/signout/success。

    除了指定logoutUrl外,我们也可以通过logoutSuccessHandler指定退出成功处理器来处理退出成功后的逻辑:

    @Autowired private MyLogOutSuccessHandler logOutSuccessHandler;...... .and().logout().logoutUrl("/signout")// .logoutSuccessUrl("/signout/success").logoutSuccessHandler(logOutSuccessHandler).deleteCookies("JSESSIONID") .and() ......

    MyLogOutSuccessHandler实现LogoutSuccessHandler:

    @Component public class MyLogOutSuccessHandler implements LogoutSuccessHandler {@Overridepublic void onLogoutSuccess(HttpServletRequest httpServletRequest, HttpServletResponse httpServletResponse, Authentication authentication) throws IOException, ServletException {httpServletResponse.setStatus(HttpStatus.UNAUTHORIZED.value());httpServletResponse.setContentType("application/json;charset=utf-8");httpServletResponse.getWriter().write("退出成功,请重新登录");} }

    效果和上面一样:

    2. 源码地址

    退出登录

    总结

    以上是生活随笔为你收集整理的Spring Security 退出登录(7)的全部内容,希望文章能够帮你解决所遇到的问题。

    如果觉得生活随笔网站内容还不错,欢迎将生活随笔推荐给好友。