微信退款通知接口说明: https://pay.weixin.qq.com/wiki/doc/api/native.php?chapter=9_16&index=11
重点:
Java本身限制密钥的长度最多128位,而AES256需要的密钥长度是256位,
因此需要到Java官网上下载一个java Cryptography Extension (JCE) Unlimited Strength Jurisdiction Policy Files。
在Java SE的下载页面下面的Additional Resources那里会有下载链接。下载后打开压缩包,里面有两个jar文件。
把这两个jar文件解压到JRE目录下的lib/security文件夹,覆盖原来的文件。这样Java就不再限制密钥的长度了。
jdk8 下载地址: http://www.oracle.com/technetwork/java/javase/downloads/jce8-download-2133166.html
解密util:
AES256EncryptionUtil 源码:
package cn.dong.utils.security; import org.bouncycastle.jce.provider.BouncyCastleProvider; import sun.misc.BASE64Decoder; import sun.misc.BASE64Encoder; import javax.crypto.Cipher; import javax.crypto.spec.SecretKeySpec; import java.io.IOException; import java.security.Security; /** * Created by dong on 2017/8/7. */ public class AES256EncryptionUtil { public static boolean initialized = false; public static final String ALGORITHM = "AES/ECB/PKCS7Padding"; /** * @param str String 要被加密的字符串