关于源代码点击地址进行下载:http://download.csdn.net/download/zhihua_w/10261363
基于PHP和JS的AES相互加密解密方法详解(CryptoJS)
基于PHP和JS的AES相互加密解密方法详解(CryptoJS)
注意说明:
- 1. 首先引入CryptoJS包中的aes.js和pad-zeropadding.js
- 2. 其次引入了jquery.min.js和自己封装的function.js(内容主要是加密解密函数)
- 3. 加密解密过程中的向量和密钥必须保持一致
- 4. 进行加密的数据(字符串类型):{"username":"1001","password":"123456","terminal":"PC"}
- 5. 加密结果是变化的在这不写(变化的原因是因为密钥取得是当前时间)
- 6. 具体详情可读代码(注释完整)
加密测试:
- 进行加密的数据(字符串类型):{"username":"1001","password":"123456","terminal":"PC"}
解密测试:
-
进行解密密的数据(字符串类型、PHP端生成):8bkd/doBOrG3+pTEGkRwk9A3ZLrzXtf10E6Nn9CSoHXRXHydM7xt7PllPhUSItuK8ciF5g6UZ7DruCPQCVNZIJzI4ZHyUMJlV2aHyqMhbEoyS3pK6lPs1MsOeU/H7BZ5
- 解密的密钥(PHP端生成):
- JS解密后字符串:
JS(funciton.js)代码
/**
* ===============================================
* Author: ZHIHUA·WEI <968959@qq.com.com>
* Project: 基于PHP和JS的AES相互加密解密方法详解(CryptoJS)
* Power: Javascript common function
* ===============================================
*/
/**
* 接口数据加密函数
* @param str string 需加密的json字符串
* @param key string 加密key(16位)
* @param iv string 加密向量(16位)
* @return string 加密密文字符串
*/
function encrypt(str, key, iv) {
//密钥16位
var key = CryptoJS.enc.Utf8.parse(key);
//加密向量16位
var iv = CryptoJS.enc.Utf8.parse(iv);
var encrypted = CryptoJS.AES.encrypt(str, key, {
iv: iv,
mode: CryptoJS.mode.CBC,
padding: CryptoJS.pad.ZeroPadding
});
return encrypted;
}
/**
* 接口数据解密函数
* @param str string 已加密密文
* @param key string 加密key(16位)
* @param iv string 加密向量(16位)
* @returns {*|string} 解密之后的json字符串
*/
function decrypt(str, key, iv) {
//密钥16位
var key = CryptoJS.enc.Utf8.parse(key);
//加密向量16位
var iv = CryptoJS.enc.Utf8.parse(iv);
var decrypted = CryptoJS.AES.decrypt(str, key, {
iv: iv,
mode: CryptoJS.mode.CBC,
padding: CryptoJS.pad.ZeroPadding
});
return decrypted.toString(CryptoJS.enc.Utf8);
}
PHP(index.php)代码
'1001', 'password' => '123456', 'terminal' => 'PC');
//转换成json字符串
$encrypt_data = json_encode($arr);
$encrypted = encrypt($encrypt_data, $encrypt_key, $iv);
//加密结果
var_dump($encrypted);
exit;
//********************************结束**********************************
//******************************集成函数********************************
/**
* 加密字符串
* @param string $data 字符串
* @param string $key 加密key
* @param string $iv 加密向量
* @return string
*/
function encrypt($data, $key, $iv)
{
$encrypted = mcrypt_encrypt(MCRYPT_RIJNDAEL_128, $key, $data, MCRYPT_MODE_CBC, $iv);
return base64_encode($encrypted);
}
/**
* 解密字符串
* @param string $data 字符串
* @param string $key 加密key
* @param string $iv 加密向量
* @return object
*/
function decrypt($data, $key, $iv)
{
$decrypted = mcrypt_decrypt(MCRYPT_RIJNDAEL_128, $key, base64_decode($data), MCRYPT_MODE_CBC, $iv);
$json_str = rtrim($decrypted, "\0");
return json_decode($json_str);
}
前端demo
基于PHP和JS的AES相互加密解密方法详解(CryptoJS)
基于PHP和JS的AES相互加密解密方法详解(CryptoJS)
注意说明:
- 1. 首先引入CryptoJS包中的aes.js和pad-zeropadding.js
- 2. 其次引入了jquery.min.js和自己封装的function.js(内容主要是加密解密函数)
- 3. 加密解密过程中的向量和密钥必须保持一致
- 4. 进行加密的数据(字符串类型):{"username":"1001","password":"123456","terminal":"PC"}
- 5. 加密结果是变化的在这不写(变化的原因是因为密钥取得是当前时间)
- 6. 具体详情可读代码(注释完整)
加密测试:
- 进行加密的数据(字符串类型):{"username":"1001","password":"123456","terminal":"PC"}
解密测试:
-
进行解密密的数据(字符串类型、PHP端生成):8bkd/doBOrG3+pTEGkRwk9A3ZLrzXtf10E6Nn9CSoHXRXHydM7xt7PllPhUSItuK8ciF5g6UZ7DruCPQCVNZIJzI4ZHyUMJlV2aHyqMhbEoyS3pK6lPs1MsOeU/H7BZ5
- 解密的密钥(PHP端生成):
- JS解密后字符串:
//第一步,引入
本文共 个字数,平均阅读时长 ≈ 分钟,您已阅读:0时0分0秒。
649494848