Java Springboot 如何利用Redis完成Session操作(登录,注销等)


前沿

在Java Web开发中,如果你要做动态网页或者记录用户的相关信息等等,必然会或多或少涉及到Session的操作。

Session

session是什么呢?简单地来说,相当于一个有时间限制的会话“身份ID”,它维持了一段时间的客户端和服务器的会话,保证服务器知道和它的客户端是谁,客户端是否还在有效期等;具体的专业解释,在网上有很多,请自行查阅

痛点

  1. 原始的Session是存在内存中,如果机器或者进程重启,Session就会消失,用户在本来的有效期内还是会重新登录
  2. 如果将Session存放在MySql之类的数据库中,虽然保证了重启后session不会消失,但是管理Session将会是很繁琐的,而且还会遇到很多并发的问题

如何解决呢?

Springboot本身结合了Redis这样的缓存数据库,session的操作都是自动,不用考虑重启和各种管理问题,也可以应对适量的并发(大量的并发问题暂不考虑)

Redis

Redis众所周知是一个速度很快(可以直接从内存中读取)的Key-Value数据结构的数据库,通常用来做缓存,或者存储类型简单的数据,而且它有一套很完善的数据有效期机制。因此,Springboot就默认采用Redis来存储Session

开工

1.导入redis和session所需要的库(pom.xml)

在pom.xml文件中,添加


    
    
    
  1. <!--Redis依赖-->
  2. <dependency>
  3. <groupId>org.springframework.boot </groupId>
  4. <artifactId>spring-boot-starter-redis </artifactId>
  5. <version>1.4.7.RELEASE </version>
  6. </dependency>
  7. <dependency>
  8. <groupId>org.springframework.session </groupId>
  9. <artifactId>spring-session-data-redis </artifactId>
  10. <!--<version>2.0.6</version>-->
  11. </dependency>

2.Redis数据库的配置(application.properties)

在application.properties文件中,添加以下的配置(简化版,甚至都不用配置Configuration):


    
    
    
  1. #Redis相关配置
  2. spring.redis.host=localhost
  3. spring.redis.port= 6379

3.定义一个登录注销的Contoller

因为Springboot默认采用redis来存储管理Session,因此,我们也不必手动添加或者移除session,Springboot会自动帮我们管理


    
    
    
  1. package com.helang.session;
  2. import org.springframework.web.bind.annotation.RequestMapping;
  3. import org.springframework.web.bind.annotation.RequestMethod;
  4. import org.springframework.web.bind.annotation.RestController;
  5. import javax.servlet.http.HttpServletRequest;
  6. import javax.servlet.http.HttpSession;
  7. /**
  8. * 用户登录注销Controller
  9. * @author helang
  10. */
  11. @RequestMapping
  12. @RestController
  13. public class LoginController {
  14. /**
  15. * 这里为了能简单在浏览器响应,暂时使用GET请求,
  16. * @return
  17. */
  18. @RequestMapping(value = "login",method = RequestMethod.GET)
  19. public String login(HttpServletRequest request){
  20. String account = request.getParameter( "account");
  21. String password = request.getParameter( "password");
  22. if ( "123".equals(account) && "123456".equals(password)){
  23. /*如果已经存在Session的话,直接返回它;没有就创建一个,再返回
  24. * 当然Session是自动放在response中的Header中的,这里不用做其他处理*/
  25. request.getSession();
  26. } else {
  27. return "failed";
  28. }
  29. return "success";
  30. }
  31. /**
  32. * 判断用户的session是否有效(在同一个浏览器中,同一个域中,每次Request请求,都会带上Session)
  33. * @param request
  34. * @return
  35. */
  36. @RequestMapping(value = "isValid",method = RequestMethod.GET)
  37. public String isSessionValid(HttpServletRequest request){
  38. //简化if-else表达式(其实很多地方可以简化的,这里为了方便新手朋友可以看得顺畅点,我尽量不简化)
  39. return request.isRequestedSessionIdValid() ? "ok": "no";
  40. }
  41. /**
  42. * 注销登录
  43. * @param session
  44. * @return
  45. */
  46. @RequestMapping(value = "logout",method = RequestMethod.GET)
  47. public String logout(HttpSession session){
  48. session.invalidate(); //使Session变成无效,及用户退出
  49. return "logout";
  50. }
  51. }

效果

1.登录

很明显,session是放在response中的header的返回给客户端的;之后客户端的每次请求的Request的header都会带上这个session

2.服务器检查session是否有效

默认情况下,session有效期是30分钟,当然你也可以修改,这里就不做演示了;利用session的有效期,你可以控制客户端的相关业务的请求操作

3.注销登录(用户退出登录)

就一行代码:session.invalidate(); 是不是比起其他框架来说,要简单得多呢

4.再次检查session是否有效

可以看到客户端的session已经失效了,客户端也可以根据这个结果,做相应的操作,比如让用户回到登录页面,重新登录

扩展

当然,结合Redis,我们可以很容易分布式Session,即共享Session,方便用户能够单点登录

总结

Springboot确实简化了JavaWeb开发的操作;当然,我们也不能停留到表面的业务操作中,在合适的时候,一定要深入Springboot中的源码中去,才能解决很多棘手的问题,也才能体会到Spring的博大精深

Github

代码很少,也很简单,我也把代码分享到Github中,方便新手朋友们学习

https://github.com/helang1991/SpringbootSession

原创:https://blog.csdn.net/helang296479893/article/details/83787798


免责声明!

本站转载的文章为个人学习借鉴使用,本站对版权不负任何法律责任。如果侵犯了您的隐私权益,请联系本站邮箱yoyou2525@163.com删除。



 
粤ICP备18138465号  © 2018-2025 CODEPRJ.COM