php 7.2 openssl加密,PHP7.*通过openssl_encrypt实现AES加密实现php/js互通加密/解密

php7.1以后mcrypt_encrypt将会被废弃,所以我们使用openssl_decrypt和openssl_encrypt的组合方式实现AES加密实现php/js互通加密/解密。

一、PHP加密解密

$data = 'ABCDEFGH';

$key = "1234567898882222";

$iv = '8NONwyJtHesysWpM';

// 加密

$encode = base64_encode(openssl_encrypt($data,"AES-128-CBC",$key,true,$iv));

// 解密

$decode = openssl_decrypt(base64_decode($encode),"AES-128-CBC",$key,true,$iv);

$lists = array("encode"=>$encode,"decode"=>$decode,"iv"=>$iv,"key"=>$key,"data"=>$data);

var_dump($lists);

?>

二、js端的加密解密

js端使用CryptoJS封装的库。

AES

var IV = '8NONwyJtHesysWpM';

var KEY = '1234567898882222';

var data = 'ABCDEFGH';

// 加密

function encrypt(str) {

var key = CryptoJS.enc.Utf8.parse(KEY);

var iv = CryptoJS.enc.Utf8.parse(IV);

var encrypted = CryptoJS.AES.encrypt(str,key,{iv:iv,mode:CryptoJS.mode.CBC,padding:CryptoJS.pad.Pkcs7});

return encrypted.toString();

}

// 解密

function decrypt(str) {

var key = CryptoJS.enc.Utf8.parse(KEY);

var iv = CryptoJS.enc.Utf8.parse(IV);

var decrypted = CryptoJS.AES.decrypt(str,key,{iv:iv,padding:CryptoJS.pad.Pkcs7});

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

}

var encode = encrypt(data);

var decode = decrypt(encode);

console.log(JSON.stringify({"encode":encode,"decode":decode,"iv":IV,"key":KEY,"data":data}));

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值