java关于微信小程序AES解密

1.springboot项目添加依赖

<!--微信AES用户信息解密-->
<!-- https://mvnrepository.com/artifact/commons-codec/commons-codec -->
<dependency>
   <groupId>commons-codec</groupId>
   <artifactId>commons-codec</artifactId>
   <version>1.10</version>
</dependency>

2.直接上干货代码(常量和工具类)

package com.zjht.memberserver.util;

import org.springframework.beans.factory.annotation.Value;

/**
 * @Author: pxx
 * @Description:
 * @Date: Create in  2020/9/18 16:46
 */
public class WxConstant {

    @Value("${app.smallprocedures.id}")
    private String appid;

    @Value("${app.smallprocedures.secret}")
    private String secret;

    @Value("${app.smallprocedures.url}")
    private String appSmallproceduresUrl;
    

    public static final String AES = "AES";
    public static final String AES_CBC_PADDING = "AES/CBC/PKCS7Padding";
}
package com.zjht.memberserver.util;

import org.apache.commons.codec.binary.Base64;

import javax.crypto.Cipher;
import javax.crypto.KeyGenerator;
import javax.crypto.spec.IvParameterSpec;
import javax.crypto.spec.SecretKeySpec;
import java.security.AlgorithmParameters;
import java.security.Key;
import java.security.Security;

/**
 * @Author: pxx
 * @Description:
 * @Date: Create in  2020/9/18 16:42
 */
public class WxUtils {


/**
 *    加密数据解密算法
 *   接口如果涉及敏感数据(如wx.getUserInfo当中的 openId 和 unionId),接口的明文内容将不包含这些敏感数据。开发者如需要获取敏感数据,需要对接口返回的加密数据(encryptedData) 进行对称解密。 解密算法如下:
 *   对称解密使用的算法为 AES-128-CBC,数据采用PKCS#7填充。
 *   对称解密的目标密文为 Base64_Decode(encryptedData)。
 *   对称解密秘钥 aeskey = Base64_Decode(session_key), aeskey 是16字节。
 *   对称解密算法初始向量 为Base64_Decode(iv),其中iv由数据接口返回。
 *   
 *    * @param encrypted 加密数据
 *    * @param session_key 会话密钥 session_key
 *    * @param iv 加密算法的初始向量
 *
 */
 
        public static String wxDecrypt(String encrypted, String session_key, String iv) {
            String result = null;
            byte[] encrypted64 = Base64.decodeBase64(encrypted);
            byte[] key64 = Base64.decodeBase64(session_key);
            byte[] iv64 = Base64.decodeBase64(iv);
            try {
                init();
                result = new String(decrypt(encrypted64, key64, generateIV(iv64)),"UTF-8");
            } catch (Exception e) {
                e.printStackTrace();
            }
            return result;
        }

        /**
         *    * 初始化密钥
         *
         */

        public static void init() throws Exception {
            Security.addProvider(new org.bouncycastle.jce.provider.BouncyCastleProvider());
            KeyGenerator.getInstance(WxConstant.AES).init(128);
        }

        /**
         *    * 生成iv
         *
         */
        public static AlgorithmParameters generateIV(byte[] iv) throws Exception {
            // iv 为一个 16 字节的数组,这里采用和 iOS 端一样的构造方法,数据全为0
            // Arrays.fill(iv, (byte) 0x00);
            AlgorithmParameters params = AlgorithmParameters.getInstance(WxConstant.AES);
            params.init(new IvParameterSpec(iv));
            return params;
        }

        /**
         *    * 生成解密
         *
         */
        public static byte[] decrypt(byte[] encryptedData, byte[] keyBytes, AlgorithmParameters iv)
                throws Exception {
            Key key = new SecretKeySpec(keyBytes, WxConstant.AES);
            Cipher cipher = Cipher.getInstance(WxConstant.AES_CBC_PADDING);
            // 设置为解密模式
            cipher.init(Cipher.DECRYPT_MODE, key, iv);
            return cipher.doFinal(encryptedData);
        }


}

3.调用测试

public ResultInfo getWxPhone(JSONObject json) {
    String encryptedData = json.getString("encryptedData");
    String session_key = json.getString("session_key");
    String iv = json.getString("iv");
    String phone = null;
    try {
        String result = WxUtils.wxDecrypt(encryptedData, session_key, iv);
        JSONObject resultjson = JSONObject.parseObject(result);
        logger.info("========微信返回手机号信息======="+result);
        if (resultjson.containsKey("phoneNumber")) {
            phone = resultjson.getString("phoneNumber");
            String appid = resultjson.getJSONObject("watermark").getString("appid");
            if (StringUtils.isNotBlank(phone)) {

            } else {
                logger.info("该用户未绑定手机号");
                return  new ResultInfo(ServerMsgEnum.FAIL.getServerCode(), "该用户未绑定手机号");
            }
        }
    } catch (Exception e) {
        e.printStackTrace();
    }
    return   new ResultInfo(ServerMsgEnum.SUCCESS.getServerCode(), ServerMsgEnum.SUCCESS.getServerMsg(), phone);
}
  • 2
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值