zoukankan      html  css  js  c++  java
  • 阿里巴巴fastjson的使用问题

    最近项目里用到了阿里巴巴的fastjson工具,遇到一些问题,记录分享一下

    github说明:

    fastjson是阿里巴巴的开源JSON解析库,它可以解析JSON格式的字符串,支持将Java Bean序列化为JSON字符串,也可以从JSON字符串反序列化到JavaBean。

    使用:

    添加maven依赖

    <dependency>
        <groupId>com.alibaba</groupId>
        <artifactId>fastjson</artifactId>
        <version>1.2.54</version>
    </dependency>

    API使用

    String text = JSON.toJSONString(obj); //序列化
    VO vo = JSON.parseObject("{...}", VO.class); //反序列化

    但有时候会出现

    使用Redis 配置替换fastjson 反序列化报错 com.alibaba.fastjson.JSONException: autoType is not support

    解决方法是

    在RedisSerializer<T>的实现类中添加白名单

    //添加白名单
    static {
    ParserConfig.getGlobalInstance().addAccept("com.glz.oauthmanager");
    }
    public class FastJsonRedisSerializer<T> implements RedisSerializer<T> {
    
        public static final Charset DEFAULT_CHARSET = Charset.forName("UTF-8");
    
        private Class<T> clazz;
    
        //添加白名单
        static {
            ParserConfig.getGlobalInstance().addAccept("com.glz.oauthmanager");
        }
    
        public FastJsonRedisSerializer(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);
        }
    
    }

    如果还是不行,官方还有其他解决办法

    1. 在代码中配置

    ParserConfig.getGlobalInstance().addAccept("com.taobao.pac.client.sdk.dataobject."); 

    如果有多个包名前缀,分多次addAccept

    2. 加上JVM启动参数

        -Dfastjson.parser.autoTypeAccept=com.taobao.pac.client.sdk.dataobject.,com.cainiao. 
    

    如果有多个包名前缀,用逗号隔开

    3. 通过fastjson.properties文件配置。

    在1.2.25/1.2.26版本支持通过类路径的fastjson.properties文件来配置,配置方式如下:

    fastjson.parser.autoTypeAccept=com.taobao.pac.client.sdk.dataobject.,com.cainiao. // 如果有多个包名前缀,用逗号隔开

    二、打开autotype功能

    如果通过配置白名单解决不了问题,可以选择继续打开autotype功能,fastjson在新版本中内置了多重防护,但是还是可能会存在一定风险。两种方法打开autotype,二选一,如下:

    1、JVM启动参数

    -Dfastjson.parser.autoTypeSupport=true
    

    2、代码中设置

    ParserConfig.getGlobalInstance().setAutoTypeSupport(true); 

    如果有使用非全局ParserConfig则用另外调用setAutoTypeSupport(true);



    学会用不同的角度看待每个问题!
  • 相关阅读:
    一二线城市知名 IT 互联网公司名单!
    分布式理论- CAP定理
    Linux中安装ActiveMQ完整教程
    Nginx安装-配置负载均衡
    基于SpringBoot+Vue在线学习系统实现
    序列化多个对象和反序列化遍历一个文件中的所有对象原理讲解
    从源码看懂HashMap
    Mac在已有jdk1.8的环境下安装jdk1.6
    mac通过Parallels Desktop虚拟机实现共享windows独有软件提供的特殊网络
    算法题汇总
  • 原文地址:https://www.cnblogs.com/nisiweiLIQIYONG/p/10843581.html
Copyright © 2011-2022 走看看