Node Java相互使用AES-128-ECB对数据进行加密解密实现

Node Java相互使用AES-128-ECB对数据进行加密解密实现_第1张图片

目录

  • Node代码
  • Java代码

Node代码

import CryptoJS from 'crypto-js'

//秘钥,必须由16位字符组成
let secretKey = "aaaabbbbccccdddd"

/**
 * AES加密方法
 * @param content 要加密的字符串
 * @returns {string} 加密结果
 */
function Encrypt(content) {
    let key = CryptoJS.enc.Utf8.parse(secretKey);
    let srcs = CryptoJS.enc.Utf8.parse(content);
    let encrypted = CryptoJS.AES.encrypt(srcs, key, {
        mode: CryptoJS.mode.ECB,
        padding: CryptoJS.pad.Pkcs7
    });
    return encrypted.toString();
}


/**
 * 解密方法
 * @param encryptStr 密文
 * @returns {string} 明文
 */
function Decrypt(encryptStr) {
    let key = CryptoJS.enc.Utf8.parse(secretKey);
    let decrypt = CryptoJS.AES.decrypt(encryptStr, key, {
        mode: CryptoJS.mode.ECB,
        padding: CryptoJS.pad.Pkcs7
    });
    return CryptoJS.enc.Utf8.stringify(decrypt).toString();
}


let encrypt = Encrypt('hello');
let decrypt = Decrypt(encrypt);
console.log('加' + encrypt);
console.log('解' + decrypt);

Java代码

import org.springframework.util.StringUtils;

import javax.crypto.Cipher;
import javax.crypto.spec.SecretKeySpec;
import java.nio.charset.StandardCharsets;
import java.util.Base64;

/**
 * @Description AES-128-ECB
 * @Date 11:16 2020/12/7
 **/
public class AesEcbUtil {

    /**
     * @Description 密钥  16位字符 必须和node端保持一致才能互相加解密
     * @Date 11:17 2020/12/7
     **/
    public static final String SECRETKEY = "aaaabbbbccccdddd";

    /**
     * AES解密
     *
     * @param encryptStr 密文
     * @param decryptKey 秘钥,必须为16个字符组成
     * @return 明文
     * @throws Exception
     */
    public static String aesDecrypt(String encryptStr, String decryptKey) throws Exception {
        if (StringUtils.isEmpty(encryptStr) || StringUtils.isEmpty(decryptKey)) {
            return null;
        }

        byte[] encryptByte = Base64.getDecoder().decode(encryptStr);
        Cipher cipher = Cipher.getInstance("AES/ECB/PKCS5Padding");
        cipher.init(Cipher.DECRYPT_MODE, new SecretKeySpec(decryptKey.getBytes(), "AES"));
        byte[] decryptBytes = cipher.doFinal(encryptByte);
        return new String(decryptBytes);
    }

    /**
     * AES加密
     *
     * @param content    明文
     * @param encryptKey 秘钥,必须为16个字符组成
     * @return 密文
     * @throws Exception
     */
    public static String aesEncrypt(String content, String encryptKey) throws Exception {
        if (StringUtils.isEmpty(content) || StringUtils.isEmpty(encryptKey)) {
            return null;
        }

        Cipher cipher = Cipher.getInstance("AES/ECB/PKCS5Padding");
        cipher.init(Cipher.ENCRYPT_MODE, new SecretKeySpec(encryptKey.getBytes(), "AES"));

        byte[] encryptStr = cipher.doFinal(content.getBytes(StandardCharsets.UTF_8));
        return Base64.getEncoder().encodeToString(encryptStr);
    }

    // 测试加密与解密
    public static void main(String[] args) {
        try {

            String content = "hello world";
            //加密
            String encrypt = aesEncrypt(content, SECRETKEY);
            System.out.println("加密字符:" + encrypt);
            //解密
            String decrypt = aesDecrypt(encrypt, SECRETKEY);
            System.out.println("解密字符:" + decrypt);
        } catch (Exception e) {
            e.printStackTrace();
        }
    }
}

就先说到这 \color{#008B8B}{ 就先说到这} 就先说到这
在下 A p o l l o \color{#008B8B}{在下Apollo} 在下Apollo
一个爱分享 J a v a 、生活的小人物, \color{#008B8B}{一个爱分享Java、生活的小人物,} 一个爱分享Java、生活的小人物,
咱们来日方长,有缘江湖再见,告辞! \color{#008B8B}{咱们来日方长,有缘江湖再见,告辞!} 咱们来日方长,有缘江湖再见,告辞!

Node Java相互使用AES-128-ECB对数据进行加密解密实现_第2张图片

你可能感兴趣的:(Java,nodeJs,加密解密,AES-128-ECB,node.js)