spring security退出方法

 自己定义一个退出方法:

   @RequestMapping({"/admin/logout.htm"})
   public String logout(HttpServletRequest request, HttpServletResponse response) {
     Authentication auth = SecurityContextHolder.getContext().getAuthentication();
     if (auth != null) {//清除认证
       new SecurityContextLogoutHandler().logout(request, response, auth);
     }

     return "redirect:/admin/login.htm";

   }

  首先是确定,用户点击登出链接的时候,是否是在已验证的前提下(这里可能是用户的session失效等情况): SecurityContextHolder.getContext().getAuthentication() 

如果上述代码获取的Authentication对象不为空,然后我们调用 SecurityContextLogoutHandler().logout(request, response, auth) 来对用户进行登出操作。 

登出的操作需要进行下面几个步骤:

        1、使HTTP Session失效,然后解绑Session上的所以已绑定的对象。   

   2、将用户的认证信息从spring security的SecurityContext中移除,以防止并发请求的问题。

   3、从当前线程中,完全的清除相关的属性值。

       到这就完成了。

转载于:https://www.cnblogs.com/wyf-love-dch/p/11126718.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值