CryptoJS前端加密和后台Java解密

后端加密和解密:

import org.springframework.util.StringUtils;
import java.nio.charset.StandardCharsets;
import java.util.Base64;

public class EncryptUtil {

//这个密钥需要是16位
public static final String KEY_DES = "aaaaaaaabbbbbbbb";

public static void main(String[] args) throws Exception {
		String old = "12345678";
		String target ="UxoeqTwLRGW9HtZEtJOcug==";

//解密
		System.out.println(EncryptUtil.aesDecryptForFront(target,EncryptUtil.KEY_DES));
	
	//加密
		System.out.println(EncryptUtil.aesEncryptForFront(old,EncryptUtil.KEY_DES));

	}


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

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


	}

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

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

	}

}



前端代码:

import CryptoJS from 'crypto-js'

//秘钥,必须由16位字符组成
let secretKey = "aaaaaaaabbbbbbbb"
const cryptoStr = {
  /**
   * AES加密方法
   * @param content 要加密的字符串
   * @returns {string} 加密结果
   */
  aesEncrypt: (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} 明文
   */
  aesDecrypt: (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();
  }
}
export default cryptoStr
  • 3
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值