代码改变世界

Linux上java解加密(AES/CBC)异常:java.lang.SecurityException: JCE cannot authenticate the provider BC

2021-08-07 11:20  猎手家园  阅读(1468)  评论(0编辑  收藏  举报

最近做了一个SM4加解密的小工具,在windows上调试没有问题,但是部署到Linux上就报错。

我使用的依赖包是:

<dependency>
    <groupId>org.bouncycastle</groupId>
    <artifactId>bcprov-jdk15on</artifactId>
    <version>1.66</version>
</dependency>

查了一些资料后,发现是由于linux版本java与windows有一些区别导致的,做如下调整:

1、将bcprov-jdk15on的版本由1.66降到1.56

2、从maven库中找到bcprov-jdk15on的jar包,将其拷贝到:$JAVA_HOME/jre/lib/ext 目录下。

3、修改一个安全属性文件:vim $JAVA_HOME/jre/lib/security/java.security

找到:

security.provider.1=sun.security.provider.Sun
security.provider.2=sun.security.rsa.SunRsaSign
security.provider.3=sun.security.ec.SunEC
security.provider.4=com.sun.net.ssl.internal.ssl.Provider
security.provider.5=com.sun.crypto.provider.SunJCE
security.provider.6=sun.security.jgss.SunProvider
security.provider.7=com.sun.security.sasl.Provider
security.provider.8=org.jcp.xml.dsig.internal.dom.XMLDSigRI
security.provider.9=sun.security.smartcardio.SunPCSC

在最后添加一条:

security.provider.10=org.bouncycastle.jce.provider.BouncyCastleProvider

 

然后,重新tomcat启动任务。