前端JS与后端PHP的相互加解密过程

作者: 乘风御上者 分类: JavaScript 发布时间: 2021-01-28 17:15

近期公司要计划推出小程序版的项目,因为项目通信过程中对数据加密,所以需要在前后端都要有加密解密操作。

作为PHPer对后端加密比较了解,直接使用 openssl_encrypt 选择合适的模式即可,但是对于前端却没有接触过。

经过查阅资料确定使用 crypto-js 作为前端加密工具,毕竟是谷歌出品,质量还是可以信赖的。

Github地址: https://github.com/brix/crypto-js

这里是源文件,需要经过编译压缩之后放入项目,偷懒一下直接找个编译好的压缩文件:

下载地址(版本号可指定): https://cdn.bootcss.com/crypto-js/4.0.0/crypto-js.min.js

// 在项目中引入 crypto-js.min.js
// 官方文档给出了简单的使用 AES-ECB

// AES-CBC 方式加密
function encryptByAES(data, key, iv){
	let keyHex = CryptoJS.enc.Utf8.parse(key)
	let ivHex = CryptoJS.enc.Utf8.parse(iv)
	let encrypted = CryptoJS.AES.encrypt(data, keyHex, {
			iv: ivHex,
			// 默认方式
			mode: CryptoJS.mode.CBC,
			// 默认方式
			padding: CryptoJS.pad.Pkcs7
		}
	)

	// 以Base64编码密文(encrypted.ciphertext.toString以十六进制方式返回)
	return encrypted.toString()
}

// AES-CBC 方式解密
function decryptByAES(ciphertext, key, iv){
	let keyHex = CryptoJS.enc.Utf8.parse(key)
	let ivHex = CryptoJS.enc.Utf8.parse(iv)
	let decrypted = CryptoJS.AES.decrypt({
			// 先将Base64编码密文解密(CryptoJs.enc.Hex.parse解密十六进制)
			ciphertext: CryptoJS.enc.Base64.parse(ciphertext)
		}, keyHex, {
			iv: ivHex,
			// 默认方式
			mode: CryptoJS.mode.CBC,
			// 默认方式
			padding: CryptoJS.pad.Pkcs7
		}
	)

	return decrypted.toString(CryptoJS.enc.Utf8)
}

这里需要注意的地方就是加密后encrypted是二进制密文,要存储及展示则需要转成Base64或者十六进制。

对于我司项目来说,通信数据居然是使用 DES-CBC 这种古老加密方式。而crypto-js虽然支持但是文档已经舍弃说明!

不过通过源码搜索,多次尝试还是让我找到正确姿势,开撸!

如果觉得我的文章对您有用,请随意赞赏。您的支持将鼓励我继续创作!

发表回复