遇到一个超级奇怪的问题java.lang.SecurityException: class “org.apache.commons.io.output.ByteArrayOutputStream“‘s

首先我的项目由Tomcat7升级为tomcat8(8.8.100)

本地代码运行没问题,放到测试服务器运行也没问题

但是放到云服务器上就出现问题了

附件上传报错

java.lang.SecurityException: class "org.apache.commons.io.output.ByteArrayOutputStream"'s signer information does not match signer information of other classes in the same package

报错的意思是:签名者信息与同一包中其他类的签名者信息不匹配

一开始放到生产测试功能的时候才发现这个问题,其他功能测试下来都没问题就这个附件上传有这个情况。

我看源码commons.io自己的一个类new了ByteArrayOutputStream,懵逼。

commons-io-2.5.jar

private DeferredFileOutputStream(int threshold, File outputFile, String prefix, String suffix, File directory) {
    super(threshold);
    this.closed = false;
    this.outputFile = outputFile;
    this.memoryOutputStream = new ByteArrayOutputStream();
    this.currentOutputStream = this.memoryOutputStream;
    this.prefix = prefix;
    this.suffix = suffix;
    this.directory = directory;
}

commons-io-2.6.jar

private DeferredFileOutputStream(int threshold, File outputFile, String prefix, String suffix, File directory, int initialBufferSize) {
    super(threshold);
    this.closed = false;
    this.outputFile = outputFile;
    this.prefix = prefix;
    this.suffix = suffix;
    this.directory = directory;
    this.memoryOutputStream = new ByteArrayOutputStream(initialBufferSize);
    this.currentOutputStream = this.memoryOutputStream;
}

生产:java version "1.8.0_281",tomcat8.5.100 commons-io-2.5.jar(异常)

自己的阿里云服务器:java version "1.8.0_202",tomcat8.5.100 commons-io-2.5.jar(异常)

commons-io-2.6.jar(无异常)

测服:   java version "1.8.0_281",tomcat8.5.100 commons-io-2.5.jar(无异常)

本地电脑:java version "1.8.0_341",tomcat8.5.100 commons-io-2.5.jar(无异常)

总的来说问题很奇怪可能是云服务器启动tomcat走的类加载器不同,导致安全策略规则不一样。

查看jvm的安全策略文件其实上面几个版本的安全策略文件都是一模一样的,官方没有修改过。

还有一点就是commons-io-2.5.jar一定是有点毛病在身上的。

虽然问题解决了,但是没有完全发现这个问题的具体原因,有没有大佬指点一下。

报错信息

java.lang.SecurityException: class "org.apache.commons.io.output.ByteArrayOutputStream"'s signer information does not match signer information of other classes in the same package
    at java.lang.ClassLoader.checkCerts(ClassLoader.java:891)
    at java.lang.ClassLoader.preDefineClass(ClassLoader.java:661)
    at java.lang.ClassLoader.defineClass(ClassLoader.java:754)
    at java.security.SecureClassLoader.defineClass(SecureClassLoader.java:142)
    at org.apache.catalina.loader.WebappClassLoaderBase.findClassInternal(WebappClassLoaderBase.java:2344)
    at org.apache.catalina.loader.WebappClassLoaderBase.findClass(WebappClassLoaderBase.java:817)
    at org.apache.catalina.loader.WebappClassLoaderBase.loadClass(WebappClassLoaderBase.java:1302)
    at org.apache.catalina.loader.WebappClassLoaderBase.loadClass(WebappClassLoaderBase.java:1150)
    at org.apache.commons.fileupload.disk.DiskFileItem.getOutputStream(DiskFileItem.java:557)
    at org.apache.commons.fileupload.FileUploadBase.parseRequest(FileUploadBase.java:362)
    at org.apache.commons.fileupload.servlet.ServletFileUpload.parseRequest(ServletFileUpload.java:126)
    at com.szk.system.service.file.FileUpload.getFileItems(FileUpload.java:211)
    at com.szk.system.service.file.FileUpload.UploadFile(FileUpload.java:68)

  • 6
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
出现"java.lang.SecurityException: JCE cannot authenticate the provider BC"的错误通常是由于Java密码扩展(JCE)无法验证提供者BC(Bouncy Castle)引起的。 解决此问题的方法可以包括以下几个步骤: 1. 确保您已正确安装了Bouncy Castle的相关jar包。根据引用,您已经尝试过添加bcprov-jdk15-135.jar和bcprov-jdk16-143.jar的依赖,但并未解决问题。请确认这些jar包是否是正确的版本,并且已正确地放置在项目的类路径下。 2. 检查您的Java安全策略文件。引用中提到了尝试使用无政策限制权限文件(Unlimited Strength Jurisdiction Policy Files),这是为了解决某些加密算法的限制问题。请确保您已正确安装并配置了这些文件。 3. 确认是否正确添加了Bouncy Castle提供者。引用中提到了添加security.provider.x=org.bouncycastle.jce.provider.BouncyCastleProvider的方法。请确保您在Java代码中正确添加了这个提供者。 4. 参考中提供的链接,查看其他开发者在类似问题上的解决方案。这个链接可能包含更多的详细步骤和配置建议,可帮助您解决此问题。 请按照以上步骤逐一排查,确认是否解决了"java.lang.SecurityException: JCE cannot authenticate the provider BC"的问题。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* [华为云服务器上遇到java.lang.SecurityException: JCE cannot authenticate the Provider BC问题处理方法...](https://blog.csdn.net/yeyuningzi/article/details/120969770)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] - *2* *3* [:error constructing MAC: java.lang.SecurityException: JCE cannot authenticate the provider BC](https://blog.csdn.net/qq_53276288/article/details/120553631)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值