SpringSession solves the problem of non-synchronization and non-sharing of distributed sessions

We kept in auth.gulimall.com in session, but the URL to jump to gulimall.com, take no saved auth.gulimall.com the session, which resulted in session under the micro-service sync issues
with a copy service Multiple, but the session can only be saved on one service, and the browser can only read the session of one service

Add dependency:

 <!--        整合Spring Session完成session共享问题 微服务自治,就不放在common里了-->
        <dependency>
            <groupId>org.springframework.session</groupId>
            <artifactId>spring-session-data-redis</artifactId>
        </dependency>

Add configuration information in the application.properties file

#session存储类型
spring.session.store-type=redis
#session存储时间,30分钟
server.servlet.session.timeout=30m

Add the annotation @EnableRedisHttpSession to the startup class GulimallAuthServerApplication to integrate redis as session storage

//开启feign客户度的远程调用功能gulimall-auth-server
//扫描feign文件夹下的带有@FeignClient注解的接口
/**
 * Spring Session 核心原理
 * @EnableRedisHttpSession 导入RedisHttpSessionConfiguration配置
 * 装饰者模式
 * 自动延期 redis中的数据是有过期时间的
 */
@EnableFeignClients(basePackages = "com.atguigu.gulimall.auth.feign")
@EnableDiscoveryClient
@SpringBootApplication
@ComponentScan("com.hjh")
@EnableRedisHttpSession//整合redis作为session储存
public class GulimallAuthServerApplication {
    
    
    public static void main(String[] args) {
    
    
        SpringApplication.run(GulimallAuthServerApplication.class, args);
    }
}

Add a custom session configuration class

//开启Spring Session功能 redis
@EnableRedisHttpSession
@Configuration
public class GulimallSessionConfig {
    
    

    /**
     * 自定义session作用域:整个网站
     * 使用一样的session配置,能保证全网站共享一样的session
     */
    @Bean
    public CookieSerializer cookieSerializer() {
    
    

        DefaultCookieSerializer defaultCookieSerializer = new DefaultCookieSerializer();
        //一级域名就是gulimall.com,那么其子域名都可以共享session
        defaultCookieSerializer.setDomainName("gulimall.com");
        defaultCookieSerializer.setCookieName("GULISESSION");

        return defaultCookieSerializer;
    }

    /**
     * json序列化机制
     */
    @Bean
    public RedisSerializer<Object> springSessionDefaultRedisSerializer(){
    
    

        return new GenericJackson2JsonRedisSerializer();
    }
}

Login code demonstration, when the user logs in, save the user information in the session

@PostMapping("/login")
    public String login(UserLoginVo vo, RedirectAttributes redirectAttributes, HttpSession session) {
    
    

        //远程登录
        R r = memberFeignService.login(vo);
        if (r.getCode() == 0) {
    
    
            //远程登录成功,将远程服务返回的entity放入session中
            MemberResVo memberResVo = r.getData("data", new TypeReference<MemberResVo>(){
    
    });
            session.setAttribute("loginUser", memberResVo);
            return "redirect:http://gulimall.com";
        }else {
    
    
            //远程登录失败
            Map<String, String> errors = new HashMap<>();
            errors.put("msg", r.getData("msg", new TypeReference<String>(){
    
    }));
            redirectAttributes.addFlashAttribute("errors", errors);
            return "redirect:http://auth.gulimall.com/login.html";
        }
    }

After the login is successful, the data will be saved in redis. The
Insert picture description here
front end can directly get the value in the session.

<ul>
   <li>
       <a th:if="${session.loginUser!=null}">欢迎您: [[${session.loginUser == null
           ?'':session.loginUser.nickname}]]</a>
       <a href="http://auth.gulimall.com/login.html" th:if="${session.loginUser==null}">欢迎您 ,请登录</a>
   </li>
   <li>
       <a th:if="${session.loginUser == null}" class="li_2"
          href="http://auth.gulimall.com/reg.html">免费注册</a>
   </li>
   <span>|</span>
   <li>
       <a href="http://member.gulimall.com/memberOrder.html">我的订单</a>
   </li>
</ul>

Insert picture description here

Guess you like

Origin blog.csdn.net/u014496893/article/details/113956268