博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
spring security退出方法
阅读量:5170 次
发布时间:2019-06-13

本文共 803 字,大约阅读时间需要 2 分钟。

 自己定义一个退出方法:

@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

你可能感兴趣的文章
lr_start_transaction/lr_end_transaction事物组合
查看>>
CodeIgniter学习笔记(四)——CI超级对象中的load装载器
查看>>
.NET CLR基本术语
查看>>
ubuntu的home目录下,Desktop等目录消失不见
查看>>
建立,查询二叉树 hdu 5444
查看>>
[Spring框架]Spring 事务管理基础入门总结.
查看>>
2017.3.24上午
查看>>
Python-常用模块及简单的案列
查看>>
LeetCode 159. Longest Substring with At Most Two Distinct Characters
查看>>
基本算法概论
查看>>
jquery动态移除/增加onclick属性详解
查看>>
JavaScript---Promise
查看>>
暖暖的感动
查看>>
Java中的日期和时间
查看>>
Django基于admin的stark组件创建(一)
查看>>
C. Tanya and Toys_模拟
查看>>
springboot jar包运行中获取资源文件
查看>>
基于FPGA实现的高速串行交换模块实现方法研究
查看>>
Java Scala获取所有注解的类信息
查看>>
delphi ,安装插件
查看>>