SpringSessionは、分散セッションの非同期化と非共有の問題を解決します

セッションをauth.gulimall.comに保存しましたが、URLがgulimall.comにジャンプし、auth.gulimall.comに保存されたセッションを取得できなかったため、マイクロサービスでのセッション同期の問題が発生しました。
同じサービスレプリケーション複数、ただし、セッションは1つのサービスにのみ保存でき、ブラウザーは1つのサービスのセッションのみを読み取ることができます。

依存関係を追加します。

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

application.propertiesファイルに構成情報を追加します

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

アノテーション@EnableRedisHttpSessionをスタートアップクラスGulimallAuthServerApplicationに追加して、redisをセッションストレージとして統合します

//开启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);
    }
}

カスタムセッション構成クラスを追加する

//开启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();
    }
}

ログインコードのデモンストレーション、ユーザーがログインするときに、セッションにユーザー情報を保存します

@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";
        }
    }

ログインが成功すると、データはredisに保存され、
ここに画像の説明を挿入
フロントエンドはセッションで値を直接取得できます。

<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>

ここに画像の説明を挿入

おすすめ

転載: blog.csdn.net/u014496893/article/details/113956268