当前位置:   article > 正文

Fastjson报autotype is not support

Fastjson报autotype is not support

系列文章目录



前言

前些天发现了一个巨牛的人工智能学习网站,通俗易懂,风趣幽默,忍不住分享一下给大家。点击跳转到网站,这篇文章男女通用,看懂了就去分享给你的码吧。
在这里插入图片描述


打开AutoType功能

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

注意:如果配置了safeMode,配置白名单也是不起作用的。
一、添加autotype白名单
添加白名单有三种方式,三选一,如下:

  1. 在代码中配置
ParserConfig.getGlobalInstance().addAccept("com.taobao.pac.client.sdk.dataobject.");
  • 1

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

  1. 加上JVM启动参数
    -Dfastjson.parser.autoTypeAccept=com.taobao.pac.client.sdk.dataobject.,com.cainiao.
  • 1

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

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

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

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

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

1、JVM启动参数

-Dfastjson.parser.autoTypeSupport=true
  • 1

2、代码中设置

ParserConfig.getGlobalInstance().setAutoTypeSupport(true);
  • 1

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

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

  1. 配置JVM启动参数
-Dfastjson.parser.deny=xx.xxx
  • 1

这里的xx.xxx是包名前缀,如果有多个包名前缀,用逗号隔开

  1. 通过fastjson.properties来配置

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

-Dfastjson.parser.deny=xx.xxx
  • 1

这里的xx.xxx是包名前缀,如果有多个包名前缀,用逗号隔开

  1. 代码中配置
ParserConfig.getGlobalInstance().addDeny("xx.xxx");
  • 1

这里的xx.xxx是包名前缀,如果有多个包名前缀,用逗号隔开

在这里插入图片描述

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/神奇cpp/article/detail/953844
推荐阅读
相关标签
  

闽ICP备14008679号