这一节主要是完善各种页面效果。
一,用户名密码登录接口存放session
之前是在微博登录成功后把用户信息放入session,用户名密码登录成功也需要把用户信息放入session。
cpp
@PostMapping(value = "/login")
public String login(UserLoginVo vo, RedirectAttributes attributes, HttpSession session) {
//远程登录
R login = memberFeignService.login(vo);
if (login.getCode() == 0) {
MemberResponseVo data = login.getData("data", new TypeReference<MemberResponseVo>() {});
session.setAttribute(LOGIN_USER,data);
return "redirect:http://gulimall.com";
} else {
Map<String,String> errors = new HashMap<>();
errors.put("msg",login.getData("msg",new TypeReference<String>(){}));
attributes.addFlashAttribute("errors",errors);
return "redirect:http://auth.gulimall.com/login.html";
}
}
session.setAttribute(LOGIN_USER,data);
登录成功后,把用户信息存入session
。
二,详情页item处理
详情页item和首页相同的逻辑,如果登录成功,显示用户名,否则提示请登录
。
三,search模块整合spring session
1,引入spring session和redis
cpp
<dependency>
<groupId>org.springframework.session</groupId>
<artifactId>spring-session-data-redis</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-data-redis</artifactId>
</dependency>
2,redis配置
cpp
spring:
redis:
host: 192.168.56.10
3,spring session 存储
cpp
spring.session.store-type=redis
4,启动类配置注解
cpp
@EnableRedisHttpSession
5,SpringSession配置类统一
cpp
package com.atguigu.gulimall.search.config;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.data.redis.serializer.GenericJackson2JsonRedisSerializer;
import org.springframework.data.redis.serializer.RedisSerializer;
import org.springframework.session.web.http.CookieSerializer;
import org.springframework.session.web.http.DefaultCookieSerializer;
@Configuration
public class GulimallSessionConfig {
@Bean
public CookieSerializer cookieSerializer() {
DefaultCookieSerializer cookieSerializer = new DefaultCookieSerializer();
//放大作用域
cookieSerializer.setDomainName("gulimall.com");
cookieSerializer.setCookieName("GULISESSION");
return cookieSerializer;
}
@Bean
public RedisSerializer<Object> springSessionDefaultRedisSerializer() {
return new GenericJackson2JsonRedisSerializer();
}
}
问题记录
登录成功后,首页不显示用户名。
原因是auth模块配置了json序列化方式,但是product模块没有配置。
解决方案
把auth模块的配置类copy到product模块即可。
cpp
@Configuration
public class GulimallSessionConfig {
@Bean
public CookieSerializer cookieSerializer() {
DefaultCookieSerializer cookieSerializer = new DefaultCookieSerializer();
//放大作用域
cookieSerializer.setDomainName("gulimall.com");
cookieSerializer.setCookieName("GULISESSION");
return cookieSerializer;
}
@Bean
public RedisSerializer<Object> springSessionDefaultRedisSerializer() {
return new GenericJackson2JsonRedisSerializer();
}
}
1. cookieSerializer()
这个方法用于配置 CookieSerializer
,它是 Spring Session 中用来序列化和反序列化 HTTP Cookie 的对象。CookieSerializer
负责处理与 HTTP Cookie 相关的操作,比如设置 Cookie 的名称、路径、域名等。
具体作用:
- 创建一个
DefaultCookieSerializer
实例。 - 设置 Cookie 的域名(
setDomainName
)为"gulimall.com"
,这表示该 Cookie 可以在整个gulimall.com
域及其子域下有效。 - 设置 Cookie 的名称(
setCookieName
)为"GULISESSION"
,这是客户端用来标识 Session 的 Cookie 名称。
目的:
- 增强 Cookie 的作用范围 :通过设置 Cookie 的域名,可以确保该 Cookie 在整个
gulimall.com
域下有效,这样就可以在不同的子域间共享 Session 信息。 - 自定义 Cookie 的名称:通过设置 Cookie 名称,可以根据需要选择一个更具辨识度的名字。
2. springSessionDefaultRedisSerializer()
这个方法用于配置 Spring Session 中 Redis 的序列化器。Redis 是一种键值存储系统,它默认使用字符串类型的数据结构。因此,当你想要将复杂的 Java 对象存储到 Redis 中时,需要对其进行序列化。
具体作用:
- 返回一个
GenericJackson2JsonRedisSerializer
实例。 - 这个序列化器使用 Jackson JSON 库将 Java 对象转换为 JSON 字符串,然后再存储到 Redis 中。
目的:
-
序列化和反序列化对象:由于 Redis 默认只支持字符串类型的值,因此需要一个序列化器将 Java 对象转换为字符串形式,以便在 Redis 中存储和检索。
-
兼容复杂对象:使用 JSON 格式可以轻松地存储和检索复杂的 Java 对象,而不仅仅是基本的数据类型。
-
cookieSerializer()
方法配置了 HTTP Cookie 的序列化器,主要用于设置 Cookie 的名称和作用范围,以便在不同的子域间共享 Session 信息。 -
springSessionDefaultRedisSerializer()
方法配置了 Redis 的序列化器,用于将 Java 对象转换为 JSON 字符串形式存储到 Redis 中,使得可以存储复杂的对象数据。
这两个方法共同作用于 Spring Session 的配置,确保了 Session 数据可以正确地在客户端和 Redis 之间传递和存储。