很多小伙伴序列化代码是这样配置的
public class FastJson2JsonRedisSerializer<T> implements RedisSerializer<T> {
public static final Charset DEFAULT_CHARSET = Charset.forName("UTF-8");
private Class<T> clazz;
public FastJson2JsonRedisSerializer(Class<T> clazz) {
super();
this.clazz = clazz;
}
@Override
public byte[] serialize(T t) throws SerializationException {
if (t == null) {
return new byte[0];
}
return JSON.toJSONString(t, SerializerFeature.WriteClassName).getBytes(DEFAULT_CHARSET);
}
@Override
public T deserialize(byte[] bytes) throws SerializationException {
if (bytes == null || bytes.length <= 0) {
return null;
}
String str = new String(bytes, DEFAULT_CHARSET);
return (T) JSON.parseObject(str, clazz);
}
可知道直接使用阿里的fastjson 需要注意很多坑:
1 主要是字段类型的转换:
场景:自增一个key的值,设置时incr 一个数字,但是get时? 是什么类型呢? 其实是动态的可能是 Integer 可能是Long,我们不得不写出这样代码:
Object count = map.get(keyPre + e);
if (null != count) {
long l = Long.parseLong(String.valueOf(count));
if (l > maxExposeTime) {
return false;
}
logger.debug("【曝光没有超限制】key = {} , count = {}",keyPre + e,count);
}
原因:
2 其他坑自查下 推荐使用jackson!