在分布式系统中,session是需要共享的
整合SpringSession解决服务session共享问题
1,引入依赖spring-session
2,session的保存地方使用redis(配置文件指定spring.session.store=redis)
3,在把session放到客户端时
问题:其他服务与该session不能共享,且存入的数据在redis时java默认的序列化
所以必须自定义SpringSession
1,编写Configuration,把cookieSerializer放入容器
2,cookieSerializer中设置作用域(domainName)
3,另外可以设置cookie中其他参数
redis存储json数据
需要把redisSerializer放入容器中
@Bean
public RedisSerializer redisSerializer() {
return new FastJsonRedisSerializer();//也可以用GenericJackson2JsonRedisSerializer()
}
Springboot拦截器
1,编写拦截器实现handlerInterceptor接口
2,把拦截器放入spring拦截器链中:创建类实现WebMvcConfigure,实现addInterceptors,把1步骤中的拦截器加入该拦截器链
Feign远程调用丢失请求头问题
feign在每个远程调用前都会调用RequestInterceptor的apply方法
编写feign的Configuration,返回RequestInterceptor配置类放入容器,
重写apply方法,把RequestContextHolder中获