zoukankan      html  css  js  c++  java
  • 谷粒商城遇到的问题

    最近在敲到整合分布式事务的时候,发现当触发自定义的异常时候,重新回退到购物车结算,却一直报错 com.alibaba.fastjson.JSONException: autoType is not support

    因为在springsession中我用的是fastjson进行序列化的,会让生成的JSON字符串中含有 @type 的属性值,在反序列化的时候就会异常。我于是就换了和视频一样的方式。

    image-20200806225816494

    官网解决方法:

    打开AutoType功能

    在1.2.25之后的版本,以及所有的.sec01后缀版本中,autotype功能是受限的,和之前的版本不同,如果在升级的过程中遇到问题,可以通过以下方法配置。

    一、添加autotype白名单

    添加白名单有三种方式,三选一,如下:

    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);

    三、配置autoType黑名单

    打开AutoType之后,是基于内置黑名单来实现安全的,但黑名单是穷举不完的,如果发现了新的风险类,可以通过以下配置来增加黑名单:

    1. 配置JVM启动参数

    -Dfastjson.parser.deny=xx.xxx
    
    • 这里的xx.xxx是包名前缀,如果有多个包名前缀,用逗号隔开

    2. 通过fastjson.properties来配置

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

    -Dfastjson.parser.deny=xx.xxx 
    
    • 这里的xx.xxx是包名前缀,如果有多个包名前缀,用逗号隔开

    3. 代码中配置

    ParserConfig.getGlobalInstance().addDeny("xx.xxx");
    
    • 这里的xx.xxx是包名前缀,如果有多个包名前缀,用逗号隔开

    在我之前的博客中,也有简单的用过:https://www.cnblogs.com/dalianpai/p/11656441.html

  • 相关阅读:
    表单
    html 基础代码
    thread
    流的存入读取
    异常

    Android——多线程编程练习题
    Android——进度对话框
    安卓3个练习题
    Android—对话框
  • 原文地址:https://www.cnblogs.com/dalianpai/p/13449720.html
Copyright © 2011-2022 走看看