java.security.NoSuchProviderException: no such provider: BC 的问题解决

需要做keystore证书报错:

java.security.NoSuchProviderException: no such provider: BC

在这里插入图片描述

处理:

1、引入jar包:bcprov-jdk16-1.45.jar

将jar包放在JAVA_HOME/jre/lib/ext/目录下。

2、修改jre环境下的security配置文件

找到JAVA_HOME/jre/lib/security/java.security文件,在里面可以看到有几行是以“security.provider.”开头的,在它的最后序号之上加一行,如我的最后的序号是9,加入以下这行:

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

这样就可以了(前提是工程自己将bcprov-jdk16-146导入了依赖包使用)

有其他交流的想法,可以加我创建的Q群:820080257

java.security.NoSuchProviderException: JCE cannot authenticate the provider BC是一个错误,意味着Java加密扩展(JCE)无法验证提供者BC的身份。这个错误通常发生在项目使用了BC加密包,并且在打包运行时出现。 解决这个问题的方法有几种: 1. 确保正确引入了BC加密包:首先,确保你已经正确地将BC加密包添加到项目的依赖中,并且版本与你的项目要求的版本相匹配。你可以尝试重新下载和添加正确的BC加密包。 2. 检查权限文件:如果你的项目需要使用无限强度的加密算法,则应该确保已经下载并正确安装了“Unlimited Strength Jurisdiction Policy Files”。这些文件可以解决JCE对于强加密算法的限制。 3. 添加BouncyCastleProvider:尝试通过在代码中显式添加BouncyCastleProvider解决问题。你可以在项目的源代码中添加以下代码: ```java Security.addProvider(new BouncyCastleProvider()); ``` 确保在使用BC加密功能之前添加这行代码。 4. 检查冲突的提供者:如果你的项目中同时使用了其他的加密提供者,例如cybersource,可能会导致冲突。请确保你的项目中没有引入冲突的加密提供者,并尝试解决冲突。 总结来说,解决java.security.NoSuchProviderException: JCE cannot authenticate the provider BC错误的关键是确保正确引入了BC加密包,检查权限文件,添加BouncyCastleProvider,并解决与其他加密提供者的冲突。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* [百旺电子发票发布到服务器报错.txt](https://download.csdn.net/download/sinat_26708145/12707339)[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^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 33.333333333333336%"] - *2* [java.security.NoSuchProviderException: JCE cannot authenticate the provider BC](https://blog.csdn.net/m0_37986733/article/details/126475025)[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^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 33.333333333333336%"] - *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^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 33.333333333333336%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值