Crypto的简单应用-前后端加密传输

最近遇到一个数据脱敏处理的需求,想要用一种轻量级的技术实现,必须足够简单并且适用于所有场合如前后端加密传输、路由加密、数据脱敏等。抽时间研究了一下Crypto加密库的一些API,发现完全符合上述需求,扩展也比较容易。

1、前端加解密

1、安装crypto-js,crypto-js是谷歌开发的一个纯JavaScript的加密算法类库,支持多种加密算法,可以很方便的在前端实现加解密操作。

npm install crypto-js --save-dev

2、加解密实现

const CryptoJS = require('crypto-js')

// 1.秘钥准备(密钥必须是16位十六进制数)
const key = CryptoJS.enc.Utf8.parse('SECRET_KEY_RIGHT')

// 2.偏移量准备(偏移量是可选的,iv称为初始向量,不同的iv加密后的字符串不同,iv也必须是16位十六进制数)
const iv = CryptoJS.enc.Utf8.parse('SECRET_KEY_RIGHT')

const cipherOption = {
    mode: CryptoJS.mode.ECB,
    padding: CryptoJS.pad.Pkcs7,
    iv: iv
}

// 3.加密
function encrypt(value) {
    return CryptoJS.AES.encrypt(value, key, cipherOption).toString() // base64编码
}

// 4.解密
function decrypt(value) {
    return CryptoJS.AES.decrypt(value, key, cipherOption).toString(CryptoJS.enc.Utf8);
}

// 5.测试
const value = '19987131172'

console.log(encrypt(value)); // zArydT0+/teKeIwlwuvVUQ==

console.log(decrypt("zArydT0+/teKeIwlwuvVUQ==")) // 19987131172

2、后端加解密

/**
 * @description:
 * @date: 2022/8/17 9:29
 */
public class SignUtil {
	// 加密
    public static String encrypt(String transformation, String key, String value) {
        try {
            Cipher cipher = Cipher.getInstance(transformation);
            SecretKeySpec sks = new SecretKeySpec(key.getBytes(StandardCharsets.UTF_8), "AES");
            // Cipher.ENCRYPT_MODE 加密模式
            cipher.init(Cipher.ENCRYPT_MODE, sks);
            // 加密
            byte[] encryptBytes = cipher.doFinal(value.getBytes());
            return Base64Utils.encodeToString(encryptBytes);
        } catch (Exception e) {
            LogUtil.error(e);
        }
        return null;
    }
	
	// 解密
    public static String decrypt(String transformation, String key, String encrypt) {
        try {
            Cipher cipher = Cipher.getInstance(transformation);
            SecretKeySpec sks = new SecretKeySpec(key.getBytes(StandardCharsets.UTF_8), "AES");
            // Cipher.DECRYPT_MODE 解密模式
            cipher.init(Cipher.DECRYPT_MODE, sks);
            // 解密
            byte[] decryptBytes = cipher.doFinal(Base64.getDecoder().decode(encrypt));
            return new String(decryptBytes);
        } catch (Exception e) {
            LogUtil.error(e);
        }
        return null;
    }
}

测试(我们就拿上述前端加密后的字符串zArydT0+/teKeIwlwuvVUQ==进行测试):

@Test
public void decryptTest() {
    String transformation = "AES/ECB/PKCS5Padding";
    String key = "SECRET_KEY_RIGHT";
    String value = decrypt(transformation, key, "zArydT0+/teKeIwlwuvVUQ==");
    System.out.println(value); // 19987131172
}
  • 11
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

lambda.

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值