測試工具 apiPost 可以百度下載使用
DES加密解密
前端加密使用CryptoJS插件
function encrypt(str, key, iv) {
var encode_str = '';
var key = CryptoJS.MD5(key).toString();
var iv = CryptoJS.MD5(iv).toString();
var crypto_key = CryptoJS.enc.Utf8.parse(key);
var crypto_iv = CryptoJS.enc.Utf8.parse(iv.substr(0, 8));
if (typeof (word) == 'string') {
encode_str = CryptoJS.TripleDES.encrypt(str, crypto_key, {
iv: crypto_iv,
mode: CryptoJS.mode.CBC,
padding: CryptoJS.pad.Pkcs7
});
} else {
encode_str = CryptoJS.TripleDES.encrypt(JSON.stringify(str), crypto_key, {
iv: crypto_iv,
mode: CryptoJS.mode.CBC,
padding: CryptoJS.pad.Pkcs7
});
}
return encode_str.toString();
}
function decrypt(str, key, iv) {
var key = CryptoJS.MD5(key).toString();
var iv = CryptoJS.MD5(iv).toString();
var crypto_key = CryptoJS.enc.Utf8.parse(key);
var crypto_iv = CryptoJS.enc.Utf8.parse(iv.substr(0, 8));
var decrypt_str = CryptoJS.TripleDES.decrypt(str, crypto_key, {
iv: crypto_iv,
mode: CryptoJS.mode.CBC,
padding: CryptoJS.pad.Pkcs7
});
return decrypt_str.toString(CryptoJS.enc.Utf8);
}
前端加密解密示例
console.log(encrypt({data: 1,dasd:5}, '1234567887654321', '1234567887654321'))
console.log(decrypt('4IN6uvgqsIIgcjW0pZg2J8Ir3LLz1lBF','1234567887654321', '1234567887654321'))
密碼與iv都是16位數的
後端php DES加密解密
<?php
namespace Des;
class Des
{
public static function decrypt($data, $key, $iv)
{
$data = base64_decode($data);
$key = md5($key);
$iv = substr(md5($iv), 0, 8); //取前8位
$decrypted = openssl_decrypt($data, 'des-ede3-cbc', $key, OPENSSL_RAW_DATA, $iv);
return $decrypted;
}
public static function encrypt($str, $key, $iv)
{
$key = md5($key);
$iv = substr(md5($iv), 0, 8); //取前8位
$data = base64_encode(openssl_encrypt($str, 'des-ede3-cbc', $key, OPENSSL_RAW_DATA, $iv));
return $data;
}
}
後端調用加密解密
接口測試
我們先用後端php加密字符串1,把加密的密文複製到js中看看是否可以解密?
結果是p0U/1VSUkLs=
我們將其複製粘貼到des加密解密的js中,看看
已複製好,注意密匙要與後端一致
成功解密 出來1
DES加密解密php 與js前端相同已經OK
AES加密解密
前端aes加密解密代碼
function encrypt(data, key, iv) {
let encrypted = '';
let text = data;
text = CryptoJS.enc.Base64.stringify(CryptoJS.enc.Utf8.parse(text)).toString();
key = CryptoJS.enc.Utf8.parse(key); /*爲了避免補位,直接用16位的祕鑰*/
iv = CryptoJS.enc.Utf8.parse(iv); /*16位初始向量*/
if (typeof (word) == 'string') {
encrypted = CryptoJS.AES.encrypt(text, key, {
iv: iv,
mode: CryptoJS.mode.CBC,
padding: CryptoJS.pad.ZeroPadding
}).toString();
} else {
encrypted = CryptoJS.AES.encrypt(JSON.stringify(text), key, {
iv: iv,
mode: CryptoJS.mode.CBC,
padding: CryptoJS.pad.ZeroPadding
}).toString();
}
return CryptoJS.enc.Base64.stringify(CryptoJS.enc.Utf8.parse(encrypted)).toString();
}
function decrypt(data, key, iv) {
let encrypted = CryptoJS.enc.Utf8.stringify(CryptoJS.enc.Base64.parse(data)).toString();
key = CryptoJS.enc.Utf8.parse(key); /*爲了避免補位,直接用16位的祕鑰*/
iv = CryptoJS.enc.Utf8.parse(iv); /*16位初始向量*/
let decrypted = CryptoJS.AES.decrypt(encrypted, key, {
iv: iv,
mode: CryptoJS.mode.CBC,
padding: CryptoJS.pad.ZeroPadding
}).toString(CryptoJS.enc.Utf8);
return CryptoJS.enc.Utf8.stringify(CryptoJS.enc.Base64.parse(decrypted)).toString();
}
前端aes加密解密示例
console.log(encrypt({data: 2,json: 1},'1234567887654321','1234567887654321'))
console.log(decrypt('SlNnR0diZkxuUml1Uk5oQ0EwQUVYbVNTQmVSZ2dUUkhlTUd0VVlGWGlCeGE5SmxRdm5zblJDUkRiNVJYNkl4Mg==','1234567887654321','1234567887654321'))
結果
後端aes加密解密代碼
<?php
namespace Aes;
class Aes
{
public function encrypt($data, $key, $iv)
{
$base64_str = base64_encode(json_encode($data));
$encrypted = openssl_encrypt($base64_str, "aes-128-cbc", $key, OPENSSL_ZERO_PADDING, $iv);
return base64_encode($encrypted);
}
public function decrypt($data, $key, $iv)
{
$encrypted = base64_decode($data);
$decrypted = openssl_decrypt($encrypted, 'aes-128-cbc', $key, OPENSSL_ZERO_PADDING, $iv);
return json_decode(base64_decode($decrypted), true);
}
}
調用示例
public function decryptAes(Request $request)
{
$aes = new Aes();
$post = $request->post();
$data = $aes->decrypt($post['data'], '1234567887654321', '1234567887654321');
return callJson::back(200, 'aes解密結果', $data);
}
public function encryptAes(Request $request)
{
$aes = new Aes();
$post = $request->post();
$str = $aes->encrypt(['username' => 'admin', 'pwd' => 'admin'], '1234567887654321', '1234567887654321');
return callJson::back(200, 'aes加密結果', $str);
}
結果
同des一樣,我們將後端接口加密的密文複製到js中看看是否可以解密?
console.log(decrypt(‘SlNnR0diZkxuUml1Uk5oQ0EwQUVYbVNTQmVSZ2dUUkhlTUd0VVlGWGlCeGE5SmxRdm5zblJDUkRiNVJYNkl4Mg==’,‘1234567887654321’,‘1234567887654321’))
查看結果
解密是相通的至此,des與aes加密解密前端後端的統一就都OK了,本篇文章中所有的密匙都是一樣的,位數是做過處理的,比如des加密,會將密匙 md5,然後截取前8位,這樣aes與des可以用同一對密碼和iv,如果項目中有需要用到aes和des加密的,可以看看這篇文章參考參考。
文章原文地址:DES加密解密 與php後端加密解密互通