方法一

package com.ecarpo.bms.wx.common;import java.security.AlgorithmParameters;
import java.security.InvalidAlgorithmParameterException;
import java.security.InvalidKeyException;
import java.security.Key;
import java.security.NoSuchAlgorithmException;
import java.security.NoSuchProviderException;
import java.security.Security;import javax.crypto.BadPaddingException;
import javax.crypto.Cipher;
import javax.crypto.IllegalBlockSizeException;
import javax.crypto.NoSuchPaddingException;
import javax.crypto.spec.IvParameterSpec;
import javax.crypto.spec.SecretKeySpec;
import org.bouncycastle.jce.provider.BouncyCastleProvider;/*** AES加密* @author liuyazhuang**/
public class AES {public static boolean initialized = false;/*** AES解密* * @param content*            密文* @return* @throws InvalidAlgorithmParameterException* @throws NoSuchProviderException*/public byte[] decrypt(byte[] content, byte[] keyByte, byte[] ivByte) throws InvalidAlgorithmParameterException {initialize();try {Cipher cipher = Cipher.getInstance("AES/CBC/PKCS7Padding");Key sKeySpec = new SecretKeySpec(keyByte, "AES");cipher.init(Cipher.DECRYPT_MODE, sKeySpec, generateIV(ivByte));// 初始化byte[] result = cipher.doFinal(content);return result;} catch (NoSuchAlgorithmException e) {e.printStackTrace();} catch (NoSuchPaddingException e) {e.printStackTrace();} catch (InvalidKeyException e) {e.printStackTrace();} catch (IllegalBlockSizeException e) {e.printStackTrace();} catch (BadPaddingException e) {e.printStackTrace();} catch (NoSuchProviderException e) {// TODO Auto-generated catch blocke.printStackTrace();} catch (Exception e) {// TODO Auto-generated catch blocke.printStackTrace();}return null;}public static void initialize() {if (initialized)return;Security.addProvider(new BouncyCastleProvider());initialized = true;}// 生成ivpublic static AlgorithmParameters generateIV(byte[] iv) throws Exception {AlgorithmParameters params = AlgorithmParameters.getInstance("AES");params.init(new IvParameterSpec(iv));return params;}
}

  

package com.ecarpo.bms.wx.common;import org.apache.commons.codec.binary.Base64;import net.sf.json.JSONObject;/*** 封装对外访问方法* @author liuyazhuang**/
public class WXCore {private static final String WATERMARK = "watermark";private static final String APPID = "appid";/*** 解密数据* @return* @throws Exception*/public static String decrypt(String appId, String encryptedData, String sessionKey, String iv){String result = "";try {AES aes = new AES();  byte[] resultByte = aes.decrypt(Base64.decodeBase64(encryptedData), Base64.decodeBase64(sessionKey), Base64.decodeBase64(iv));  if(null != resultByte && resultByte.length > 0){  result = new String(WxPKCS7Encoder.decode(resultByte));  JSONObject jsonObject = JSONObject.fromObject(result);String decryptAppid = jsonObject.getJSONObject(WATERMARK).getString(APPID);if(!appId.equals(decryptAppid)){result = "";}}  } catch (Exception e) {result = "";e.printStackTrace();}return result;}public static void main(String[] args) throws Exception{String appId = "wx4f4bc4dec97d474b";String encryptedData = "CiyLU1Aw2KjvrjMdj8YKliAjtP4gsMZMQmRzooG2xrDcvSnxIMXFufNstNGTyaGS9uT5geRa0W4oTOb1WT7fJlAC+oNPdbB+3hVbJSRgv+4lGOETKUQz6OYStslQ142dNCuabNPGBzlooOmB231qMM85d2/fV6ChevvXvQP8Hkue1poOFtnEtpyxVLW1zAo6/1Xx1COxFvrc2d7UL/lmHInNlxuacJXwu0fjpXfz/YqYzBIBzD6WUfTIF9GRHpOn/Hz7saL8xz+W//FRAUid1OksQaQx4CMs8LOddcQhULW4ucetDf96JcR3g0gfRK4PC7E/r7Z6xNrXd2UIeorGj5Ef7b1pJAYB6Y5anaHqZ9J6nKEBvB4DnNLIVWSgARns/8wR2SiRS7MNACwTyrGvt9ts8p12PKFdlqYTopNHR1Vf7XjfhQlVsAJdNiKdYmYVoKlaRv85IfVunYzO0IKXsyl7JCUjCpoG20f0a04COwfneQAGGwd5oa+T8yO5hzuyDb/XcxxmK01EpqOyuxINew==";String sessionKey = "tiihtNczf5v6AKRyjwEUhQ==";String iv = "r7BXXKkLb8qrSNn05n0qiA==";System.out.println(decrypt(appId, encryptedData, sessionKey, iv));}
}

  

package com.ecarpo.bms.wx.common;import java.nio.charset.Charset;
import java.util.Arrays;/*** 微信小程序加解密* @author liuyazhuang**/
public class WxPKCS7Encoder {private static final Charset CHARSET = Charset.forName("utf-8");private static final int BLOCK_SIZE = 32;/*** 获得对明文进行补位填充的字节.** @param count*            需要进行填充补位操作的明文字节个数* @return 补齐用的字节数组*/public static byte[] encode(int count) {// 计算需要填充的位数int amountToPad = BLOCK_SIZE - (count % BLOCK_SIZE);if (amountToPad == 0) {amountToPad = BLOCK_SIZE;}// 获得补位所用的字符char padChr = chr(amountToPad);String tmp = new String();for (int index = 0; index < amountToPad; index++) {tmp += padChr;}return tmp.getBytes(CHARSET);}/*** 删除解密后明文的补位字符** @param decrypted*            解密后的明文* @return 删除补位字符后的明文*/public static byte[] decode(byte[] decrypted) {int pad = decrypted[decrypted.length - 1];if (pad < 1 || pad > 32) {pad = 0;}return Arrays.copyOfRange(decrypted, 0, decrypted.length - pad);}/*** 将数字转化成ASCII码对应的字符,用于对明文进行补码** @param a*            需要转化的数字* @return 转化得到的字符*/public static char chr(int a) {byte target = (byte) (a & 0xFF);return (char) target;}
}

  引入maven依赖:

package com.ecarpo.bms.wx.common;import java.nio.charset.Charset;
import java.util.Arrays;/*** 微信小程序加解密* @author liuyazhuang**/
public class WxPKCS7Encoder {private static final Charset CHARSET = Charset.forName("utf-8");private static final int BLOCK_SIZE = 32;/*** 获得对明文进行补位填充的字节.** @param count*            需要进行填充补位操作的明文字节个数* @return 补齐用的字节数组*/public static byte[] encode(int count) {// 计算需要填充的位数int amountToPad = BLOCK_SIZE - (count % BLOCK_SIZE);if (amountToPad == 0) {amountToPad = BLOCK_SIZE;}// 获得补位所用的字符char padChr = chr(amountToPad);String tmp = new String();for (int index = 0; index < amountToPad; index++) {tmp += padChr;}return tmp.getBytes(CHARSET);}/*** 删除解密后明文的补位字符** @param decrypted*            解密后的明文* @return 删除补位字符后的明文*/public static byte[] decode(byte[] decrypted) {int pad = decrypted[decrypted.length - 1];if (pad < 1 || pad > 32) {pad = 0;}return Arrays.copyOfRange(decrypted, 0, decrypted.length - pad);}/*** 将数字转化成ASCII码对应的字符,用于对明文进行补码** @param a*            需要转化的数字* @return 转化得到的字符*/public static char chr(int a) {byte target = (byte) (a & 0xFF);return (char) target;}
}

  

方法二

package com.ecarpo.bms.wx.utils;import java.io.UnsupportedEncodingException;
import java.security.Key;
import java.security.NoSuchAlgorithmException;
import java.security.Security;
import java.util.Arrays;import javax.crypto.Cipher;
import javax.crypto.NoSuchPaddingException;
import javax.crypto.spec.IvParameterSpec;
import javax.crypto.spec.SecretKeySpec;import org.apache.commons.codec.binary.Base64;
import org.bouncycastle.jce.provider.BouncyCastleProvider;public class WxAESUtils {//算法名称final String KEY_ALGORITHM = "AES";// 加解密算法/模式/填充方式final String algorithmStr = "AES/CBC/PKCS7Padding";private Key key;private Cipher cipher;/*** 解密* * @param encryptedDataStr* @param keyBytesStr* @param ivStr* @return* @author wangyue* @since 2018.08.15*/public byte[] decrypt(String encryptedDataStr, String keyBytesStr, String ivStr) {byte[] encryptedText = null;byte[] encryptedData = null;byte[] sessionkey = null;byte[] iv = null;try {sessionkey = Base64.decodeBase64(keyBytesStr);encryptedData = Base64.decodeBase64(encryptedDataStr);iv = Base64.decodeBase64(ivStr);init(sessionkey);cipher.init(Cipher.DECRYPT_MODE, key, new IvParameterSpec(iv));encryptedText = cipher.doFinal(encryptedData);} catch (Exception e) {e.printStackTrace();}return encryptedText;}public void init(byte[] keyBytes) {// 如果密钥不足16位,那么就补足. 这个if 中的内容很重要int base = 16;if (keyBytes.length % base != 0) {int groups = keyBytes.length / base + (keyBytes.length % base != 0 ? 1 : 0);byte[] temp = new byte[groups * base];Arrays.fill(temp, (byte) 0);System.arraycopy(keyBytes, 0, temp, 0, keyBytes.length);keyBytes = temp;}// 初始化Security.addProvider(new BouncyCastleProvider());// 转化成JAVA的密钥格式key = new SecretKeySpec(keyBytes, KEY_ALGORITHM);try {// 初始化ciphercipher = Cipher.getInstance(algorithmStr);} catch (NoSuchAlgorithmException e) {e.printStackTrace();} catch (NoSuchPaddingException e) {e.printStackTrace();}}public static void main(String[] args) {WxAESUtils s = new WxAESUtils();String encryptedDataStr = "CiyLU1Aw2KjvrjMdj8YKliAjtP4gsMZM\"\n"+ "    \"QmRzooG2xrDcvSnxIMXFufNstNGTyaGS\"\n"+ "    \"9uT5geRa0W4oTOb1WT7fJlAC+oNPdbB+\"\n"+ "    \"3hVbJSRgv+4lGOETKUQz6OYStslQ142d\"\n"+ "    \"NCuabNPGBzlooOmB231qMM85d2/fV6Ch\"\n"+ "    \"evvXvQP8Hkue1poOFtnEtpyxVLW1zAo6\"\n"+ "    \"/1Xx1COxFvrc2d7UL/lmHInNlxuacJXw\"\n"+ "    \"u0fjpXfz/YqYzBIBzD6WUfTIF9GRHpOn\"\n"+ "    \"/Hz7saL8xz+W//FRAUid1OksQaQx4CMs\"\n"+ "    \"8LOddcQhULW4ucetDf96JcR3g0gfRK4P\"\n"+ "    \"C7E/r7Z6xNrXd2UIeorGj5Ef7b1pJAYB\"\n"+ "    \"6Y5anaHqZ9J6nKEBvB4DnNLIVWSgARns\"\n"+ "    \"/8wR2SiRS7MNACwTyrGvt9ts8p12PKFd\"\n"+ "    \"lqYTopNHR1Vf7XjfhQlVsAJdNiKdYmYV\"\n"+ "    \"oKlaRv85IfVunYzO0IKXsyl7JCUjCpoG\"\n"+ "    \"20f0a04COwfneQAGGwd5oa+T8yO5hzuy\"\n" + "    \"Db/XcxxmK01EpqOyuxINew==";String keyBytesStr = "tiihtNczf5v6AKRyjwEUhQ==";String ivStr = "r7BXXKkLb8qrSNn05n0qiA==";byte[] decrypt = s.decrypt(encryptedDataStr, keyBytesStr, ivStr);String str;try {str = new String(decrypt, "utf-8");System.out.println(str);} catch (UnsupportedEncodingException e) {e.printStackTrace();}}}

微信小程序解密过程(java)相关推荐

  1. java微信小程序解密AES/CBC/PKCS7Padding

    摘要:微信小程序解密建议使用1.6及以上的环境使用maven下载jar包org.bouncycastlebcprov-jdk15on1.55加密类代码importorg.bouncycastle.jc ...

  2. 微信小程序解密用户信息--java解密

    1.wx.login()方法获取code,通过code换取session_key 2.wx.getUserInfo()方法获取: encryptedData 包括敏感数据在内的完整用户信息的加密数据 ...

  3. 微信小程序 登录过程

    微信小程序 登录过程 本文由笔者自己经验所得,不妥之处还望指教: 微信代码 php后端代码 流程 小程序请求code 小程序请求encryptedData 后端请求session_key 后端解密 小 ...

  4. 微信小程序商城 (后台JAVA)

    微信小程序商城(Java版) 技术选型 1 后端使用技术 1.1 springframework4.3.7.RELEASE 1.2 mybatis3.4.1 1.3 shiro1.3.2 1.4 se ...

  5. 深入讲解微信小程序上传图片与JAVA后台的结合

    背景 微信小程序上传文件是微信小程序提供的API之一,如果用JAVA后台如何来处理上传的文件呢? 官方文档 UploadTask wx.uploadFile(Object object) 将本地资源上 ...

  6. 微信小程序获取UnionId - Java后台解决

    UnionId 是微信平台用户的唯一标识,对于后台开发来说,UnionId 无疑是一个非常好用的东西. 前言 在获取 UnionId 之前,首先需要做下面的准备: 在小程序平台完善自己的微信小程序信息 ...

  7. 开发微信小程序的过程记录

    目录 1.运用阿里巴巴的IconFont 2.小程序需要运用到的路由类型 3.绝对定位下的水平居中实现 4.选择图片和视频 5. 小程序连接数据库 6.存储多个对象的数组 7. 上传图片等文件至服务器 ...

  8. 实现阿里云物联网平台设备信息到微信小程序分享过程

    简要说明: 实现微信小程序连接阿里云物联网平台并且显示阿里云设备信息等,设备端采用模拟设备进行数据上传,并且利用规则引擎和自定义的Topic进行信息的接受和发送. 目前效果图 步骤: 1.注册阿里云物 ...

  9. 微信小程序与后端Java接口交互-图书搜索实现

    完整微信小程序(Java后端) 技术贴目录清单页面(必看) 我们模拟实现一个微信小程序端关键字图书,然后显示图书列表的功能,如下图: 实现大体思路,前端用户输入关键字,通过bindtap事件,事件里得 ...

最新文章

  1. OpenResty 最佳实践
  2. 浅显易懂讲讲网关和DNS的概念—Vecloud微云
  3. adb刷入第三方recovery_橙狐Recovery一款另类功能丰富的第三方刷机工具支持MIUI OTA...
  4. 唯美动态个人404单页HTML源码
  5. cloudflare 利用API将域名批量解析到cloudflare
  6. Eureka、Zookeeper、Consul异同点
  7. RQNOJ:PID4 数列
  8. 安装 Office 2010 错误 error 1935和数据库以及安卓路线
  9. EasyMicroPlot: 一种快速进行微生物下游分析的整合R包
  10. 用matlab画树叶,matlab画漂亮的树叶
  11. Java相同类型的两个对象比较属性值,得到不同属性的名称和对应的值,附代码实例
  12. uniapp 腾讯云活体人脸核身(超详细)
  13. 如何让一个div跟随鼠标移动
  14. SpringBoot实现CRUD
  15. Ehabs Last Corollary
  16. 分支定界法需要注意的是什么
  17. 使用SyncNavigator轻松实现数据库异地同步、断点续传、异构同步
  18. web快速入门之基础篇-html:2、基本标签之标题标签、段落标签、换行标签
  19. 數字圖像中邊緣檢測算法綜合研究
  20. 一种自动化挖掘联网车辆协议中的拒绝服务漏洞的方案

热门文章

  1. 用.Net Core接入微信公众号开发
  2. 笔记 | 产品经理必懂的技术(五)
  3. Ui设计中常用的6大工具
  4. 数据平台开发是做什么的?需要具备哪些能力
  5. MySQL数据库基础(1)数据库基础
  6. 环境监测系统/智能监测平台---Vue/Node.js
  7. mos管的rc吸收电路计算_一种反激式开关电源中MOS管的RC吸收电路的制作方法
  8. VGGNet网络结构
  9. java 缓存的简单实现
  10. 足以代替Apache的Nginx