java.security.NoSuchProviderException: no such provider: Crypto

因项目需求,需要用到AES加密解密,但在运行时 sr = SecureRandom.getInstance(SHA1PRNG, "Crypto"); 出现了异常:java.security.NoSuchProviderException: no such provider: Crypto,原因是在Android 7.0以上没有"Crypto"。

解决方法:

我们需要自己写一个类:

public static class CryptoProvider extends Provider {
        public CryptoProvider() {
            super("Crypto", 1.0, "HARMONY(SHA1 digest;SecureRandom;SHA1withDSA signature)");
            put("SecureRandom.SHA1PRNG", "org.apache.harmony.security.provider.crypto.SHA1PRNG_SecureRandomImpl");
            put("SecureRandom.SHA1PRNG ImplementedIn", "Software");
        }
    }

然后把代码中的:

sr = SecureRandom.getInstance(SHA1PRNG, "Crypto");

替换为:

sr = SecureRandom.getInstance(SHA1PRNG, new CryptoProvider());
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
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 ]
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值