• 摘要:微信小程序解密建议使用1.6及以上的环境使用maven下载jar包org.bouncycastlebcprov-jdk15on1.55加密类代码importorg.bouncycastle.jce.provider.BouncyCastleProvider;importorg.bouncycastle.util.Arrays;importjavax.crypto.Cipher;importjavax.crypto.NoSuchPaddingException;importja
  • 微信小程序解密

    建议使用1.6及以上的环境

    使用maven下载jar包

    org.bouncycastle 
    bcprov-jdk15on 
    1.55

    加密类代码

    import org.bouncycastle.jce.provider.BouncyCastleProvider;
    import org.bouncycastle.util.Arrays;
    import javax.crypto.Cipher;
    import javax.crypto.NoSuchPaddingException;
    import javax.crypto.spec.IvParameterSpec;
    import javax.crypto.spec.SecretKeySpec;
    import java.security.Key;
    import java.security.NoSuchAlgorithmException;
    import java.security.NoSuchProviderException;
    import java.security.Security;
    /**
    * Created by wind on 2016/12/24.
    */
    /**
    *
    * @author ngh
    * AES128 算法
    *
    * CBC 模式
    *
    * PKCS7Padding 填充模式
    *
    * CBC模式需要添加一个参数iv--对称解密算法初始向量 iv
    *
    * 介于java 不支持PKCS7Padding,只支持PKCS5Padding 但是PKCS7Padding 和 PKCS5Padding 没有什么区别
    * 要实现在java端用PKCS7Padding填充,需要用到bouncycastle组件来实现
    */
    public class Pkcs7Encoder {
    // 算法名称
    static final String KEY_ALGORITHM = "AES";
    // 加解密算法/模式/填充方式
    static final String algorithmStr = "AES/CBC/PKCS7Padding";
    private static Key key;
    private static Cipher cipher;
    boolean isInited = false;
    //默认对称解密算法初始向量 iv
    static byte[] iv = { 0x30, 0x31, 0x30, 0x32, 0x30, 0x33, 0x30, 0x34, 0x30, 0x35, 0x30, 0x36, 0x30, 0x37, 0x30, 0x38 };
    public static 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 {
    // 初始化cipher
    cipher = Cipher.getInstance(algorithmStr, "BC");
    } catch (NoSuchAlgorithmException e) {
    // TODO Auto-generated catch block
    e.printStackTrace();
    } catch (NoSuchPaddingException e) {
    // TODO Auto-generated catch block
    e.printStackTrace();
    } catch (NoSuchProviderException e) {
    // TODO Auto-generated catch block
    e.printStackTrace();
    }
    }
    /**
    * 加密方法
    * --使用默认iv时
    * @param content
    * 要加密的字符串
    * @param keyBytes
    * 加密密钥
    * @return
    */
    public static byte[] encrypt(byte[] content, byte[] keyBytes) {
    byte[] encryptedText = encryptOfDiyIV(content,keyBytes,iv);
    return encryptedText;
    } /**
    * 解密方法
    * --使用默认iv时
    * @param encryptedData
    * 要解密的字符串
    * @param keyBytes
    * 解密密钥
    * @return
    */
    public static byte[] decrypt(byte[] encryptedData, byte[] keyBytes) {
    byte[] encryptedText = decryptOfDiyIV(encryptedData,keyBytes,iv);
    return encryptedText;
    }
    /**
    * 加密方法
    * ---自定义对称解密算法初始向量 iv
    * @param content
    * 要加密的字符串
    * @param keyBytes
    * 加密密钥
    * @param ivs
    * 自定义对称解密算法初始向量 iv
    * @return 加密的结果
    */
    public static byte[] encryptOfDiyIV(byte[] content, byte[] keyBytes, byte[] ivs) {
    byte[] encryptedText = null;
    init(keyBytes);
    System.out.println("IV:" + new String(ivs));
    try {
    cipher.init(Cipher.ENCRYPT_MODE, key, new IvParameterSpec(ivs));
    encryptedText = cipher.doFinal(content);
    } catch (Exception e) {
    // TODO Auto-generated catch block
    e.printStackTrace();
    }
    return encryptedText;
    }
    /**
    * 解密方法
    *
    * @param encryptedData
    * 要解密的字符串
    * @param keyBytes
    * 解密密钥
    * @param ivs
    * 自定义对称解密算法初始向量 iv
    * @return
    */
    public static byte[] decryptOfDiyIV(byte[] encryptedData, byte[] keyBytes,byte[] ivs) {
    byte[] encryptedText = null;
    init(keyBytes);
    System.out.println("IV:" + new String(ivs));
    try {
    cipher.init(Cipher.DECRYPT_MODE, key, new IvParameterSpec(ivs));
    encryptedText = cipher.doFinal(encryptedData);
    } catch (Exception e) {
    // TODO Auto-generated catch block
    e.printStackTrace();
    }
    return encryptedText;
    }
    }

    测试类

    public class Test {
    public static void main(String[] args) throws Exception { String encryptedData = "CiyLU1Aw2KjvrjMdj8YKliAjtP4gsMZMQmRzooG2xrDcvSnxIMXFufNstNGTyaGS9uT5geRa0W4oTOb1WT7fJlAC+oNPdbB+3hVbJSRgv+4lGOETKUQz6OYStslQ142dNCuabNPGBzlooOmB231qMM85d2/fV6ChevvXvQP8Hkue1poOFtnEtpyxVLW1zAo6/1Xx1COxFvrc2d7UL/lmHInNlxuacJXwu0fjpXfz/YqYzBIBzD6WUfTIF9GRHpOn/Hz7saL8xz+W//FRAUid1OksQaQx4CMs8LOddcQhULW4ucetDf96JcR3g0gfRK4PC7E/r7Z6xNrXd2UIeorGj5Ef7b1pJAYB6Y5anaHqZ9J6nKEBvB4DnNLIVWSgARns/8wR2SiRS7MNACwTyrGvt9ts8p12PKFdlqYTopNHR1Vf7XjfhQlVsAJdNiKdYmYVoKlaRv85IfVunYzO0IKXsyl7JCUjCpoG20f0a04COwfneQAGGwd5oa+T8yO5hzuyDb/XcxxmK01EpqOyuxINew==";
    String iv="r7BXXKkLb8qrSNn05n0qiA==";
    String sessionKey = "tiihtNczf5v6AKRyjwEUhQ==";
    toStr(sessionKey,encryptedData,iv);
    }
    private static void toStr(String sessionKey,String encryptedData ,String iv) throws Exception{
    byte[] sessionKeyBy = BASE64.decryptBASE64(sessionKey.getBytes());
    byte[] encryptedDataBy = BASE64.decryptBASE64(encryptedData.getBytes());
    byte[] ivBy = BASE64.decryptBASE64(iv.getBytes());
    byte[] dec = Pkcs7Encoder.decryptOfDiyIV(encryptedDataBy, sessionKeyBy,ivBy);
    System.out.println(new String(dec));
    }

    测试类中的Base64 带测试方法 
    import org.apache.commons.codec.binary.Base64;
    /** * BASE64加密解密 */ public class BASE64 { /** * BASE64解密 * @param key * @return * @throws Exception */ public static byte[] decryptBASE64(byte[] key) throws Exception { return (new Base64()).decode(key); } /** * BASE64加密 * @param key * @return * @throws Exception */ public static byte[] encryptBASE64(byte[] key) throws Exception { return (new Base64()).encode(key); } public static void main(String[] args) throws Exception { byte[] data = BASE64.encryptBASE64("http://aub.iteye.com/".getBytes()); System.out.println("加密前:" + new String(data)); byte[] byteArray = BASE64.decryptBASE64(data); System.out.println("解密后:" + new String(byteArray)); } } 完成

    会出现的一些错误:

    cannot load mian class

    打包成jar包以后,在正式运行执行:java bcprov-jdk150on-1.55.jar之前,需要删除 .jar包中的一个文件:META-INF/BCKEY.DSA

    no such provider: BC 
    在jdk中的jre/lib/security修改java.security文件, security.provider.6=com.sun.security.sasl.Provider 下面添加 security.provider.7=org.bouncycastle.jce.provider.BouncyCastleProvider
    在/jre/lib/ext中添加bcprov-jdk15-135.jar的jar包
    bcprov-jdk16-143.jar提供加密,解密,生成密钥对等方法 
    下载网址:http://download.csdn.net/download/tomliguocai/3945936

    文章大部分代码来自http://windcoder.com/jinjiweixinxiaochengxu-javabanaescbcpkcs7paddingjiajiemizifuchuan/

转载于:https://www.cnblogs.com/telwanggs/p/9927202.html

java微信小程序解密AES/CBC/PKCS7Padding相关推荐

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

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

  2. 基于java微信小程序的校园二手商城设计与实现

    基于java微信小程序的二手商城设计与实现 首先介绍一下SpringSecurity安全登陆框架 微信小程序 我用的是mysql数据库 这是我小程序的用例图 系统总体功能架构图 系统功能模块设计 数据 ...

  3. 牛逼的uniapp+Java微信小程序商城来了

    牛逼的uniapp+Java微信小程序商城来了 减少重复造轮子,开源微信小程序商城(前后端开源:uniapp+Java),秒杀.优惠券.多商户.直播卖货.分销等功能.快速搭建一个属于自己的微信小程序商 ...

  4. JAVA 微信小程序AES解密数据 demo

    这个链接是官方文档的地址,但是demo下载中没有java的demo https://developers.weixin.qq.com/miniprogram/dev/framework/open-ab ...

  5. 微信小程序解密过程(java)

    方法一 package com.ecarpo.bms.wx.common;import java.security.AlgorithmParameters; import java.security. ...

  6. java微信小程序授权微信登录获取手机号

    微信小程序获取手机号流程 1.先调用微信登录wx.login()获取code,通过code在后台获取session_key和openid(为了安全方面的原因,请不要直接使用这些信息作为你小程序的用户标 ...

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

    获取用户encryptKey | 微信开放文档 (qq.com) 一.需求 前端传值:encryptedData.iv.code 二.解密用户信息 step1:将code发送给微信服务器,获取open ...

  8. 微信小程序解密出来是乱码的问题

    直接贴代码看: 在wxDecrypt方法的返回String字符串的时候,没有加utf-8的时候,是乱码,加了以后就解决了 import org.apache.commons.codec.binary. ...

  9. 微信小程序解密手机号码异常

    在后台解密用户手机号码时,偶尔会报以下异常: javax.crypto.BadPaddingException: Given final block not properly padded. Such ...

最新文章

  1. mysql数据没有真正提交,转MySQL 批量提交优化
  2. python操作excel-openpyxl(1)
  3. 编译FileMon出错
  4. Front End Developer Questions 前端开发人员问题(三)JavaScript部分
  5. 笔记本电脑没有鼠标怎么右键_联想笔记本电脑没有声音怎么修复
  6. Unity手游之路lt;七gt;角色控制器
  7. linux脚本打印循环次数,shell脚本编程基础(3)——循环用法
  8. 虚拟现实技术利用计算机,虚拟现实技术在计算机专业教学中的应用思考
  9. 关于使用在webforms里使用routing遇到的问题
  10. C语言 程序代码编写规范
  11. SLAM Cartographer(3)定位和子图构建节点
  12. 25岁房贷上万濒临失业,大专小哥转行软件测试“挽救”人生
  13. 变量名可以是python的关键字_python – 如何使用关键字作为变量名?
  14. OpenHarmony学习笔记——编辑器访问Linux服务器进行编译
  15. 镁光闪存颗粒对照表_内存颗粒型号识别
  16. 论文笔记2:Combining Lexical, Syntactic, and Semantic Features with Maximum Entropy Models for Extracting
  17. 微信小程序获取今日天气预报api 免费接口
  18. 金融风控之贷款违约预测
  19. 乐山市计算机学校的董事长是,乐山市计算机学校开学典礼隆重举行
  20. FreeRTOS中相对延时和绝对延时的区别

热门文章

  1. xml中else if写法_面试官:优化代码中大量的if/else,你有什么方案?
  2. 分布式存储--理解分布式文件系统、分布式块存储、分布式对象存储、分布式数据库
  3. Scala 函数式编程
  4. 一直跳出来 visual_六天时间排出来肾结石,这种经历再也不要了
  5. (21)Verilog HDL结构:task语句
  6. (01)Verilog HDL介绍
  7. java两个小球相撞_JAVA小游戏之两个物体碰撞产生的碰撞检测
  8. QCostomPlot 示例注解 2
  9. STM32F103_EXTI外部中断
  10. STM32 串口详解