解决:java.security.NoSuchAlgorithmException:Cannot find any provider supporting AES/CBC/PKCS7Padding小记

由于小程序开发的需求,需要在后台对微信接口返回的敏感信息加密数据进行解密,以便开发使用,但是,在解密时出现以下异常:

java.security.NoSuchAlgorithmException: Cannot find any provider supporting AES/CBC/PKCS7Padding

网上查找原因,是java原生jdk不支持PKCS7Padding填充方式,解决方式有很多,比如有人说PKCS5Padding与PKCS7Padding填充方式差别不大,都可以用。
很遗憾的是在我这并没有生效。

于是我继续在知识的海洋中(bei)沉(rou)浮(lin)!

很幸运找到一个博主的博文,但是吧,恕我学识尚浅,我依然没解决我的问题,但是我感觉,我已经接近真相了,加油!!!

于是我继续在知识的海洋中(bei)沉(rou)浮(lin)!

<<<<<<<<<<<<<<<<<<<我是沉(rou)浮(lin)的分界线>>>>>>>>>>>>>>>>>>>>>>

终于,在我的不屑努力下,找到了明确的,小白至尊指导,大家请看博文,或者 看 我 下 面 (~ - ^ -)~

解决方式:

  1. 在 jdk安装目录中(%JAVA_HOME%\jre\lib\ext)添加 jar 包 bcprov-jdk16-1.46.jar。(我添加的是这个,下载的最新的,下载地址来自上面那篇博文,版本与原博文不太一样,但亲测可用)

  2. 在 jdk安装目录下( %JAVA_HOME%\jre\lib\security )修改 java.security 文件,将第74行(我的是在74行)的 security.provider.7=com.sun.security.sasl.Provider 替换为security.provider.7=org.bouncycastle.jce.provider.BouncyCastleProvider

    注意提醒以下,记得备份这个文件,万一崩了,就jj了

然后,运行项目,OK,成功解密。

另外有一个地方需要注意以下:

Cipher cipher = Cipher.getInstance("AES/CBC/PKCS7Padding","BC");

其中的 "BC"需要加上,不然会报异常:

javax.crypto.BadPaddingException: pad block corrupted

原因:因为BC是一个provider,而org.bouncycastle.jce.provider.BouncyCastleProvider是个第三方的库。如果jce自带的就可以不用加BC,但是JCE不支持PKCS7Padding的填充方式。

借鉴博文:
https://www.cnblogs.com/chen-lhx/p/6233954.html
https://my.oschina.net/u/269777/blog/1801356
https://blog.csdn.net/yuanhangLVli/article/details/82152178

你可能感兴趣的:(WeChat小程序,Exception)