spring-session自定义序列化

本文探讨了spring-session默认使用JDK序列化存在的效率和内存问题,并介绍了如何利用Jackson库自定义序列化方法。在实现过程中,通过保存类信息与bean序列化结果一起存储在Redis中,解决了反序列化时的问题。然而,对于含有泛型的bean,需要获取第一个元素的class以确保正确反序列化。此外,针对spring-session在删除attribute时不彻底的情况,作者通过分析源码,提出了解决方案,即在序列化null时返回空字节数组。
摘要由CSDN通过智能技术生成

spring-session默认采用jdk序列化方法,该方法效率低下、内存占用大,且需要额外修改代码。故需要自定义序列化方法


自定义序列方法使用jackson库


首先需要一个类作为序列化的工具,需要实现

RedisSerializer

该接口在反序列化时没有提供对应的class对象,因此使用jackson反序列化时,都会返回成Object对象


因此我的解决思路是,在序列化时,获取对应bean的class,将其和bean序列化后的结果一并返回,存入redis

反序列化时,首先将byte数组转化成字符串,在从中截取存入的class字符串,作为参数传入jackson反序列化方法中

问题:对于带有泛型的bean,无法将其转化成真正适合的类型

解决方案:对于list,map,set等集合类,获取其第一个元素的class,存入redis

缺点:要求集合类元素必须是同一个子类,不能来自于同一个父类


问题:spring-session在删除attribute时,并没有真正从redis中删除,只是将value置为null,此时也会调用该类做序列化

解决方案:查看spring-session源码得知,对于null值得处理方法为直接返回一个个数为0的byte数组,反序列化时直接返回null即可


import cn.nsu.edu.web.four.config.BaseStatic;
import com.fasterxml.jackson.core.JsonProcessingException;
import com.fasterxml.jackson.databind.JavaType;
import com.fasterxml.jackson.databind.ObjectMapper;
import com.fasterxml.jackson.databind.type.TypeFactory;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.data.redis.serializer.RedisSerializer;
import org.springframework.data.redis.serializer.SerializationException;
import org.springframework.data.redis.serializer.SerializationUtils;

import java.io.IOException;
import java.io.UnsupportedEncodingException;
import java.util.*;
import java.util.regex.Matcher;
import java.util.regex.
好的,我可以回答你关于 Spring Boot 自定义序列化 Session 的问题。 在 Spring Boot 中,Session 默认使用 Java序列化方式进行存储。如果你想要自定义序列化方式,可以通过实现 Spring Session 的 Serializer 接口,并在配置文件中指定该序列化器来实现。 下面是一个使用 Kryo 序列化器的示例代码: 首先,在 pom.xml 文件中添加 Kryo 序列化器的依赖: ```xml <dependency> <groupId>com.esotericsoftware</groupId> <artifactId>kryo</artifactId> <version>5.1.1</version> </dependency> <dependency> <groupId>org.springframework.session</groupId> <artifactId>spring-session-core</artifactId> </dependency> ``` 然后,创建一个 KryoSerializer 类,实现 Serializer 接口,并实现相应的序列化和反序列化方法,如下所示: ```java public class KryoSerializer<T> implements Serializer<T> { private final ThreadLocal<Kryo> kryos = ThreadLocal.withInitial(() -> { Kryo kryo = new Kryo(); kryo.setReferences(false); kryo.register(Session.class); return kryo; }); @Override public void serialize(T t, OutputStream outputStream) throws IOException { Kryo kryo = kryos.get(); Output output = new Output(outputStream); kryo.writeObject(output, t); output.close(); } @Override public T deserialize(InputStream inputStream) throws IOException { Kryo kryo = kryos.get(); Input input = new Input(inputStream); T t = (T) kryo.readObject(input, Session.class); input.close(); return t; } } ``` 最后,在 Spring Boot 的配置文件中指定使用 Kryo 序列化器,如下所示: ```properties spring.session.store-type=redis spring.redis.host=localhost spring.redis.port=6379 spring.redis.password= spring.redis.timeout=10000 spring.session.redis.flush-mode=on_save spring.session.redis.namespace=spring:session spring.session.serializer.type=kryo ``` 以上就是关于 Spring Boot 自定义序列化 Session 的步骤,希望能帮到你。
评论 5
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值