java.lang.SecurityException: JCE cannot authenticate the provider BC

本文解决因使用密文连接数据库导致的java.lang.SecurityException错误,介绍如何配置BouncyCastleProvider及正确放置bcprov-jdk13-146.jar。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

程序改用密文连接数据库后,启动报错:java.lang.SecurityException: JCE cannot authenticate the provider BC
看到报错明细,确实是用了密文导致的,因为解密的时候用到了Cipher

java.lang.SecurityException: JCE cannot authenticate the provider BC
        at javax.crypto.Cipher.getInstance(Cipher.java:657)
        at javax.crypto.Cipher.getInstance(Cipher.java:596)

也是网上百度参考了些帖子
解决方案为
1、 在系统使用的(JAVA_HOME 指向那个) jdk中,/usr/java/jdk1.6.0_45/jre/lib/security目录下的,在文件“java.security” 添加如下:
security.provider.9=org.bouncycastle.jce.provider.BouncyCastleProvider //这里的9,视具体情况而定,你可能是是10,11...
2、将工程里面的“bcprov-jdk13-146.jar”,拷贝到/usr/java/jdk1.6.0_45/jre/lib/ext 路径下

关于JAVA_HOME,命令java -verbose 最后两行的输出可以看到JDK的安装路径。
java.security文件就在此路径下
我的路径是 /usr/java/jdk1.6.0_45/jre/lib/security

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值