亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

java實現(xiàn)微信小程序加密數(shù)據(jù)解密算法

 更新時間:2018年09月08日 14:12:05   作者:liuyazhuang  
這篇文章主要為大家詳細介紹了java實現(xiàn)微信小程序加密數(shù)據(jù)解密算法,具有一定的參考價值,感興趣的小伙伴們可以參考一下

一、概述

微信推出了小程序,很多公司的客戶端應(yīng)用不僅具有了APP、H5、還接入了小程序開發(fā)。但是,小程序中竟然沒有提供Java版本的加密數(shù)據(jù)解密算法。這著實讓廣大的Java開發(fā)人員蛋疼。

微信小程序提供的加密數(shù)據(jù)解密算法鏈接

我們下載的算法示例如下:

木有Java?。?木有Java?。?木有Java??!

那么如何解決這個問題,我們一起來實現(xiàn)Java版本的微信小程序加密數(shù)據(jù)解密算法。

二、實現(xiàn)Java版本的微信小程序加密數(shù)據(jù)解密算法

1、創(chuàng)建項目

這里,我們創(chuàng)建一個Maven工程,具體創(chuàng)建步驟略。

2、配置pom.xml

我們在pom.xml中加入如下配置。

<dependency>
 <groupId>org.bouncycastle</groupId>
 <artifactId>bcprov-jdk16</artifactId>
 <version>1.46</version>
</dependency>
 
 <dependency>
 <groupId>commons-codec</groupId>
 <artifactId>commons-codec</artifactId>
 <version>1.4</version>
</dependency>
 
<dependency> 
 <groupId>net.sf.json-lib</groupId> 
 <artifactId>json-lib</artifactId> 
 <version>2.2.3</version> 
 <classifier>jdk15</classifier> 
</dependency>

3、實現(xiàn)AES類

package com.chwl.medical.crypto.wx;
 
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 block
 e.printStackTrace();
 } catch (Exception e) {
 // TODO Auto-generated catch block
 e.printStackTrace();
 }
 return null;
 }
 
 public static void initialize() {
 if (initialized)
 return;
 Security.addProvider(new BouncyCastleProvider());
 initialized = true;
 }
 
 // 生成iv
 public static AlgorithmParameters generateIV(byte[] iv) throws Exception {
 AlgorithmParameters params = AlgorithmParameters.getInstance("AES");
 params.init(new IvParameterSpec(iv));
 return params;
 }
}

4、實現(xiàn)WxPKCS7Encoder類

package com.chwl.medical.crypto.wx;
 
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;
 
 /**
 * 獲得對明文進行補位填充的字節(jié).
 *
 * @param count
 *  需要進行填充補位操作的明文字節(jié)個數(shù)
 * @return 補齊用的字節(jié)數(shù)組
 */
 public static byte[] encode(int count) {
 // 計算需要填充的位數(shù)
 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);
 }
 
 /**
 * 將數(shù)字轉(zhuǎn)化成ASCII碼對應(yīng)的字符,用于對明文進行補碼
 *
 * @param a
 *  需要轉(zhuǎn)化的數(shù)字
 * @return 轉(zhuǎn)化得到的字符
 */
 public static char chr(int a) {
 byte target = (byte) (a & 0xFF);
 return (char) target;
 }
}

5、實現(xiàn)WXCore類

這個類主要是對具體算法的封裝,統(tǒng)一對外提供方法。

package com.chwl.medical.crypto.wx;
 
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";
 /**
 * 解密數(shù)據(jù)
 * @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));
 }
}


三、測試

1、運行Java版微信小程序加密數(shù)據(jù)解密算法

這里我們就直接運行WXcore類的main方法,這里的測試數(shù)據(jù)都是從Python版微信小程序加密數(shù)據(jù)解密算法的示例程序中提出來的。我們的運行結(jié)果如下:

復(fù)制代碼 代碼如下:
{"openId":"oGZUI0egBJY1zhBYw2KhdUfwVJJE","nickName":"Band","gender":1,"language":"zh_CN","city":"Guangzhou","province":"Guangdong","country":"CN","avatarUrl":"http://wx.qlogo.cn/mmopen/vi_32/aSKcBBPpibyKNicHNTMM0qJVh8Kjgiak2AHWr8MHM4WgMEm7GFhsf8OYrySdbvAMvTsw3mo8ibKicsnfN5pRjl1p8HQ/0","unionId":"ocMvos6NjeKLIBqg5Mr9QjxrP1FA","watermark":{"timestamp":1477314187,"appid":"wx4f4bc4dec97d474b"}}

2、運行Python版微信小程序加密數(shù)據(jù)解密算法

這里我們在python環(huán)境中直接運行微信官方提供的Python版小程序加密數(shù)據(jù)解密算法,結(jié)果如下:

復(fù)制代碼 代碼如下:
{u'province': u'Guangdong', u'openId': u'oGZUI0egBJY1zhBYw2KhdUfwVJJE', u'language': u'zh_CN', u'city': u'Guangzhou', u'gender': 1, u'avatarUrl': u'http://wx.qlogo.cn/mmopen/vi_32/aSKcBBPpibyKNicHNTMM0qJVh8Kjgiak2AHWr8MHM4WgMEm7GFhsf8OYrySdbvAMvTsw3mo8ibKicsnfN5pRjl1p8HQ/0', u'watermark': {u'timestamp': 1477314187, u'appid': u'wx4f4bc4dec97d474b'}, u'country': u'CN', u'nickName': u'Band', u'unionId': u'ocMvos6NjeKLIBqg5Mr9QjxrP1FA'}

通過對比以上結(jié)果可知,我們自行使用Java實現(xiàn)的Java版微信小程序加密數(shù)據(jù)解密算法與微信官方提供的Python版小程序加密數(shù)據(jù)解密算法結(jié)果一致。

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • Java中的異步非阻塞AIO模型詳解

    Java中的異步非阻塞AIO模型詳解

    這篇文章主要介紹了Java中的異步非阻塞AIO模型詳解,AIO需要操作系統(tǒng)的支持,在linux內(nèi)核2.6版本中加入了對真正異步IO的支持,java從jdk1.7開始支持AIO,本文提供了部分實現(xiàn)代碼,需要的朋友可以參考下
    2023-09-09
  • java對于目錄下文件的單詞查找操作代碼實現(xiàn)

    java對于目錄下文件的單詞查找操作代碼實現(xiàn)

    這篇文章主要介紹了java對于目錄下文件的單詞查找操作代碼實現(xiàn),文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下
    2019-11-11
  • MyBatis-Plus 如何實現(xiàn)連表查詢的示例代碼

    MyBatis-Plus 如何實現(xiàn)連表查詢的示例代碼

    這篇文章主要介紹了MyBatis-Plus 如何實現(xiàn)連表查詢的示例代碼,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-08-08
  • 使用feign服務(wù)調(diào)用添加Header參數(shù)

    使用feign服務(wù)調(diào)用添加Header參數(shù)

    這篇文章主要介紹了使用feign服務(wù)調(diào)用添加Header參數(shù)的操作,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2021-06-06
  • SpringBoot集成Swagger使用SpringSecurity控制訪問權(quán)限問題

    SpringBoot集成Swagger使用SpringSecurity控制訪問權(quán)限問題

    這篇文章主要介紹了SpringBoot集成Swagger使用SpringSecurity控制訪問權(quán)限問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2024-05-05
  • Java中PriorityQueue實現(xiàn)最小堆和最大堆的用法

    Java中PriorityQueue實現(xiàn)最小堆和最大堆的用法

    很多時候都會遇到PriorityQueue,本文主要介紹了Java中PriorityQueue實現(xiàn)最小堆和最大堆的用法,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-06-06
  • spring-boot-maven-plugin:unknown的完美解決方法

    spring-boot-maven-plugin:unknown的完美解決方法

    這篇文章主要介紹了spring-boot-maven-plugin:unknown的完美解決方法,本文通過圖文并茂的形式給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2020-11-11
  • java?讀寫鎖的使用及它的優(yōu)點

    java?讀寫鎖的使用及它的優(yōu)點

    這篇文章主要介紹了java?讀寫鎖的使用及它的優(yōu)點,讀寫鎖的特點就是是讀讀不互斥、讀寫互斥、寫寫互斥,下面具體使用分享需要的小伙伴可以參考一下
    2022-05-05
  • 一鍵清除maven倉庫中下載失敗的jar包的實現(xiàn)方法

    一鍵清除maven倉庫中下載失敗的jar包的實現(xiàn)方法

    這篇文章主要介紹了一鍵清除maven倉庫中下載失敗的jar包的實現(xiàn)方法,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-07-07
  • 基于Java實現(xiàn)收發(fā)電子郵件功能

    基于Java實現(xiàn)收發(fā)電子郵件功能

    Email就是電子郵件,我們平常使用的QQ郵箱,網(wǎng)易郵箱,F(xiàn)oxmail都是用來收發(fā)郵件的,利用Java程序也可以完成收發(fā)電子郵件的功能,本文就來為大家詳細講講實現(xiàn)步驟
    2022-07-07

最新評論