SpringBoot+微信小程序 AES加密

加密解密 专栏收录该内容
1 篇文章 0 订阅

小程序代码

第一步:引入js,下载以下js放入小程序中
[https://cdn.bootcss.com/crypto-js/3.1.9-1/crypto-js.min.js]
第二步:
aseutil.js

//引入第一步的js
var CryptoJS = require('../utils/crypto-js.min.js');
 //字符串加密方法  	*注意:以下key和iv 前后台保持一致
function encrypt( data){
  var iv   = CryptoJS.enc.Latin1.parse('****************');//16位的偏移量
  var key  = CryptoJS.enc.Latin1.parse('****************');//16位的密钥
  return   CryptoJS.AES.encrypt(data, key, {iv:iv,mode:CryptoJS.mode.CBC,padding:CryptoJS.pad.ZeroPadding}).toString();
}

//字符串解密方法
function decrypt(data){
   var iv   = CryptoJS.enc.Latin1.parse('****************');//16位的偏移量
  var key  = CryptoJS.enc.Latin1.parse('****************');//16位的密钥
  var decrypted =CryptoJS.AES.decrypt(data,key,
    {
        iv:iv,
        mode:CryptoJS.mode.CBC,
        padding:CryptoJS.pad.Pkcs7
    });
   return  decrypted.toString(CryptoJS.enc.Utf8);
}

module.exports = {
    decrypt:decrypt,
    encrypt:encrypt
}

user.js

//引入上面的js
var Utils = require('../utils/aseutil.js')
//在方法中调用以下方法
   var testname="佩奇";
   let encParam = Utils.encrypt(testname); //文件名.方法名  加密
   let decParam = Utils.decrypt(encParam);//解密
   console.log("加密后"+encParam);
   console.log("解密后"+decParam);

java 加密解密


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

import javax.crypto.Cipher;
import javax.crypto.spec.IvParameterSpec;
import javax.crypto.spec.SecretKeySpec;

/**
 * @program:  
 * @description:
 * @author: 云晓得峰
 * @create: 2020-07-29 16:12
 **/
public class AesEncryptUtils {

    //使用AES-128-CBC加密模式,key需要为16位,key和iv可以相同!
    private static String KEY ="****************";

    private static String IV = "****************";


    /**
     * 加密方法
     * @param data  要加密的数据
     * @param key 加密key
     * @param iv 加密iv
     * @return 加密的结果
     * @throws Exception
     */
    public static String encrypt(String data, String key, String iv) throws Exception {
        try {

            Cipher cipher = Cipher.getInstance("AES/CBC/NoPadding");//"算法/模式/补码方式"
            int blockSize = cipher.getBlockSize();

            byte[] dataBytes = data.getBytes("utf-8");
            int plaintextLength = dataBytes.length;
            if (plaintextLength % blockSize != 0) {
                plaintextLength = plaintextLength + (blockSize - (plaintextLength % blockSize));
            }

            byte[] plaintext = new byte[plaintextLength];
            System.arraycopy(dataBytes, 0, plaintext, 0, dataBytes.length);

            SecretKeySpec keyspec = new SecretKeySpec(key.getBytes(), "AES");
            IvParameterSpec ivspec = new IvParameterSpec(iv.getBytes());

            cipher.init(Cipher.ENCRYPT_MODE, keyspec, ivspec);
            byte[] encrypted = cipher.doFinal(plaintext);

            return new Base64().encodeToString(encrypted);

        } catch (Exception e) {
            e.printStackTrace();
            return null;
        }
    }

    /**
     * 解密方法
     * @param data 要解密的数据
     * @param key  解密key
     * @param iv 解密iv
     * @return 解密的结果
     * @throws Exception
     */
    public static String desEncrypt(String data, String key, String iv) throws Exception {
        try {
            byte[] encrypted1 = new Base64().decode(data.getBytes("utf-8"));

            Cipher cipher = Cipher.getInstance("AES/CBC/NoPadding");
            SecretKeySpec keyspec = new SecretKeySpec(key.getBytes(), "AES");
            IvParameterSpec ivspec = new IvParameterSpec(iv.getBytes());

            cipher.init(Cipher.DECRYPT_MODE, keyspec, ivspec);

            byte[] original = cipher.doFinal(encrypted1);
            String originalString = new String(original, "UTF-8");
            return originalString;
        } catch (Exception e) {
            e.printStackTrace();
            return null;
        }
    }

    /**
     * 使用默认的key和iv加密
     * @param data
     * @return
     * @throws Exception
     */
    public static String encrypt(String data) throws Exception {
        return encrypt(data, KEY, IV);
    }

    /**
     * 使用默认的key和iv解密
     * @param data
     * @return
     * @throws Exception
     */
    public static String desEncrypt(String data) throws Exception {
        return desEncrypt(data, KEY, IV);
    }



    /**
     * 测试
     */
    public static void main(String args[]) throws Exception {

        String test = "123456";

        String data = null;
        String key = "****************";
        String iv = "****************";

        data = encrypt(test, key, iv);

        System.out.println(data);
        String s = desEncrypt(data , key, iv);
        System.out.println( s);
    }
}

  • 0
    点赞
  • 0
    评论
  • 1
    收藏
  • 一键三连
    一键三连
  • 扫一扫,分享海报

©️2021 CSDN 皮肤主题: 数字20 设计师:CSDN官方博客 返回首页
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值