Redis使用FastJson序列化/FastJson2JsonRedisSerializer --坑

很多小伙伴序列化代码是这样配置的


public class FastJson2JsonRedisSerializer implements RedisSerializer {

    public static final Charset DEFAULT_CHARSET = Charset.forName("UTF-8");

    private Class clazz;

    public FastJson2JsonRedisSerializer(Class 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);
                }

 

原因:

Redis使用FastJson序列化/FastJson2JsonRedisSerializer --坑_第1张图片

Redis使用FastJson序列化/FastJson2JsonRedisSerializer --坑_第2张图片

Redis使用FastJson序列化/FastJson2JsonRedisSerializer --坑_第3张图片

2 其他坑自查下  推荐使用jackson!

你可能感兴趣的:(java,tomcat,redis)