linux上java解加密(AES CBC)异常

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

用mapreduce做数据清洗的时候,需要对数据进行解密,加密方法是:AES/CBC/PKCS7Padding,由于java本身不支持,需要添加依赖,以下为解决方法:

因为我的服务使用docker容器启动的,所以以下步骤需要在docker容器中进行操作

  • 1.找包:bcprov-jdk15on-1.56.jar

看看开发给的jar包里有没有:

复制代码
jar -tvf wallet-summarize-1.0-SNAPSHOT.jar | grep bcprov

如果有,解压:

复制代码
jar -xvf wallet-summarize-1.0-SNAPSHOT.jar BOOT-INF/lib/bcprov-jdk15on-1.55.jar

如果没有,下载:

复制代码
https://mvnrepository.com/artifact/org.bouncycastle/bcprov-jdk15on
  • 2.放包到:$JAVA_HOME/jre/lib/ext 下

  • 3.找到文件:$JAVA_HOME/jre/lib/security/java.security

    在security.provider.9 下新增一行:

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

  • 4.重启应用验证;


其实,以上问题是由于linux版本java与windows有一些区别导致的,解决方法如下:

  • 1、在mvn仓库中找到下载的包bcprov-jdk15on-1.56.jar,或者如果你不用maven,只要能下载到这个包,放到linux的$JAVA_HOME/jre\lib\ext下面;

  • 2、配置我的安全属性文件:vim /usr/java/jdk1.8.0_112/jre/lib/security/java.security

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

第10行是我添加的,是由自己文件内容编号来确定的;

完成这些配置后,重新执行这个任务,成功!

相关推荐
舒一笑16 小时前
程序员效率神器:一文掌握 tmux(服务器开发必备工具)
运维·后端·程序员
Johny_Zhao17 小时前
centos7安装部署openclaw
linux·人工智能·信息安全·云计算·yum源·系统运维·openclaw
雨中飘荡的记忆17 小时前
保证金系统入门到实战
java·后端
Nyarlathotep011317 小时前
Java内存模型
java
haibindev17 小时前
在 Windows+WSL2 上部署 OpenClaw AI员工的实践与踩坑
linux·wsl2·openclaw
NineData19 小时前
数据库管理工具NineData,一年进化成为数万+开发者的首选数据库工具?
运维·数据结构·数据库
暮色妖娆丶1 天前
不过是吃了几年互联网红利罢了,我高估了自己
java·后端·面试
NE_STOP1 天前
MyBatis-参数处理与查询结果映射
java