Web应用全栈之旅-Spring篇(一)分布式Session

209 阅读2分钟

banner窄.png

铿然架构  |  作者  /  铿然一叶 这是铿然架构的第 12 篇原创文章

相关阅读:

萌新快速成长之路
如何编写软件设计文档
JAVA编程思想(一)通过依赖注入增加扩展性
JAVA编程思想(二)如何面向接口编程
JAVA编程思想(三)去掉别扭的if,自注册策略模式优雅满足开闭原则
JAVA编程思想(四)Builder模式经典范式以及和工厂模式如何选?
Java编程思想(七)使用组合和继承的场景
JAVA基础(一)简单、透彻理解内部类和静态内部类
JAVA基础(二)内存优化-使用Java引用做缓存
JAVA基础(三)ClassLoader实现热加载
JAVA基础(四)枚举(enum)和常量定义,工厂类使用对比
JAVA基础(五)函数式接口-复用,解耦之利刃
Seata源码(一)初始化
Seata源码(二)事务基础对象
Seata源码(三)事务处理类结构和流程
Seata源码(四)全局锁GlobalLock
Seata源码(五)Seata数据库操作
Seata源码(六)Seata的undo日志操作
Seata源码(七)Seata事务故障处理
Seata源码(八)Seata事务生命周期hook
Seata源码(九)TCC核心类和处理逻辑
Seata源码(十)RM接收到请求后的调用过程
Seata源码(十一)TC接收到请求后的处理过程\


一、分布式Session的Redis实现

在微服务架构下,需要支持分布式Session,分布式Session可以通过Redis来实现,也可以通过数据库来实现,本文介绍Redis实现。

二、安装Redis

下载地址:github.com/MSOpenTech/…
选择对应的版本安装。

进入安装目录启动Redis。

三、pom文件

        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-data-redis</artifactId>
        </dependency>
		
		<dependency>
		    <groupId>org.springframework.session</groupId>
		    <artifactId>spring-session-data-redis</artifactId>
		</dependency>

		<dependency>
		    <groupId>org.apache.commons</groupId>
		    <artifactId>commons-pool2</artifactId>
		</dependency>

四、yml配置

yml配置如下:

# Redis服务器地址
spring.redis.host=localhost
# Redis服务器连接端口
spring.redis.port=6379

五、Config配置

config配置如下:

@Configuration
@EnableRedisHttpSession(maxInactiveIntervalInSeconds = 86400 * 30)
public class SessionConfig {

}

六、登陆后设置Session

登陆成功后设置Session信息,代码如下:

@Component
@RestController
public class LoginController {

	@RequestMapping("/login")
	public String login(@RequestBody String userId, HttpSession  session) throws Exception {
		session.setAttribute(Constants.SESSION_USER_ID, userId);
		return "Login success.";
	}
}

七、Session鉴权过滤器

没有成功登陆并设置Session,需要跳转到错误页面, 代码实例如下:

@Configuration
public class SessionFilter extends OncePerRequestFilter {

	@Override
	protected void doFilterInternal(HttpServletRequest request, HttpServletResponse response, FilterChain filterChain)
			throws ServletException, IOException {

		if (isNeedAuth(request)) {
			Object userIdObject = request.getSession().getAttribute(Constants.SESSION_USER_ID);
			if (null == userIdObject) {
				response.sendRedirect("/errorPage");
			}
		}

		filterChain.doFilter(request, response);
	}
}

以上为实现Redis Session的所有步骤,完整实例代码扫码加入微信公众号并回复:webfullstack,获取仓库地址。

end.