微信退款 java工具类,微信支付中退款踩坑记录

首先附上微信支付的开发者文档

其实这里所说的踩坑记录,无非就是微信在开发者文档上的写不太明确,也没有比较官方的demo,在此列出一个可行的demo,供大家下载使用。

主要问题就是在这几步解密上

eec1fe4ce05960c63906fd7b0fda3dc1.png

微信的解密算法

首先是base64解码的工具类

cd974378a7b74044518addede40a5a9c.png

base64Utils

这个工具类都是比较简单的,大部分的框架都会封装这种类似的工具类,这里自己做简单封装

然后是md5工具类,这个就不往外放了,网上多的是,现成的也多的是

主要坑人的地方是第三条。。。

477c43e1c7461addb6b0030727e71e51.png

解密参数设置

4da1b54c29697f8625f1e67e22c7fe36.png

AES解密方法

上面写明了用AES-256-ECB-PKCS7Padding,但是你把下面的ALGORITHM_MODE_PADDING参数换成AES/ECB/PKCS7Padding,发现报了这么个异常

java.security.NoSuchAlgorithmException: Cannot find any provider supporting DES/ECB/PKCS7Padding,

然后把参数改成AES/ECB/PKCS5Padding,发现 Illegal key size or default parameters

解决方法:

JDK8 jar包下载地址:

JDK7 jar包下载地址:

JDK6 jar包下载地址:

把里面的两个jar包:local_policy.jar 和 US_export_policy.jar 替换掉原来jdk安装目录Java\jre\lib\security 下的两个jar包接可以了

然后运行一些试试,,此时代码正常,数据正常。。。

因为某些国家的进口管制限制,Java发布的运行环境包中的加解密有一定的限制。比如默认不允许256位密钥的AES加解密,解决方法就是修改策略文件,  从官方网站下载JCE无限制权限策略文件,注意自己JDK的版本别下错了。将local_policy.jar和US_export_policy.jar这两个文件替换%JRE_HOME%\lib\security和%JDK_HOME%\jre\lib\security下原来的文件,注意先备份原文件。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值