【异常】java11提示: Cannot find any provider supporting RSA/ECB/PKCS1Padding的问题

本文主要介绍了在Java 11环境下遇到的加密问题,即无法找到支持RSA/ECB/PKCS1Padding的提供者。原因是JRE不兼容,与JDK8存在差异。为解决这个问题,提出了两种步骤:一是通过POM文件引入依赖,二是使用Security.addProvider方法添加BouncyCastleProvider。文章提供了详细的方法实现和样例代码。

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

一、背景

项目中需要对敏感字段进行加密,但是加密方法中涉及到比较复杂的加密算法,这些算法都需要一个Provider,主要是用于初始化算法的。
以下是遇到的具体问题

二、报错截图

在这里插入图片描述

java.security.NoSuchAlgorithmException: Cannot find any provider supporting RSA/ECB/PKCS1Padding

三、报错原因

原因是我们运行的jre不支持,对方使用的是JDK8,而我们的是JDK11
不仅出现了上面的问题,而且,对于对方已经加密的字符串,我们无法正常解析。
那这两者有什么区别呢?估计是模块化的区别。
见文章
Java9的新特性模块化(Module)

四、问题解决

4.1 Step1、引入POM文件

<!-- https://mv
### 关于Java JAR包在Windows上启动时报`NoSuchAlgorithmException`异常问题 当遇到`java.security.NoSuchAlgorithmException: No such algorithm: RSA/ECB/PKCS1Padding`错误时,这通常意味着请求的安全算法未被JCE(Java Cryptography Extension)识别或支持[^1]。 对于指定的SM4 ECB PKCS5Padding模式,在确保使用的加密库确实实现了该算法的同时,还需要确认安全策略文件允许使用此算法。如果是在较新的Java版本中运行旧版应用程序,则可能需要安装不受限强度的Jurisdiction Policy Files来扩展默认权限范围。 另外一种常见情况是由于拼写错误或是不兼容的参数组合引起的。例如,“RSA/ECB/PKCS1Padding”的表述方式并不适用于所有环境;而针对SM4应采用类似于“SM4/ECB/PKCS5Padding”的形式。因此建议仔细核对所使用的具体算法名称及其变体是否正确无误。 为了验证并解决问题: - 检查当前环境中已加载的所有提供者列表以及它们所提供的服务,可以通过如下代码片段实现: ```java import java.security.Provider; import java.security.Security; public class ListProviders { public static void main(String[] args) { for (Provider provider : Security.getProviders()) { System.out.println(provider.getName() + ":\n" + provider.toString()); } } } ``` - 如果发现缺少必要的提供者或者其注册失败,则需进一步排查类路径设置、依赖项冲突等问题。 - 对于某些特定场景下无法找到所需算法的情况,可以尝试引入第三方库如BouncyCastle作为补充选项,并通过调用`Security.addProvider(new BouncyCastleProvider());`将其加入到全局可用的服务提供商之中。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

本本本添哥

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值