ss加密php,js前端加密,php后端解密(crypto-js,openssl_decrypt)
基于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解密后字符串:
/**
* 接口數據加密函數
* @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
});returnencrypted;
}/**
* 接口數據解密函數
* @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 CryptoJS.enc.Utf8.stringify(decrypted);
}
//********************************加密**********************************
//獲取當前時間戳13位 + 3位字符
var timestamp = new Date().getTime().toString() + "WZH";//加密密鑰16位
var encrypt_key =timestamp;//加密向量16位
var iv = 'ZZWBKJ_ZHIHUAWEI';//要加密的數據
var encrypt_string = '{"username":"1001","password":"123456","terminal":"PC"}';//加密后密文(加密函數在function.js文件中)
var encrypted_string = encrypt(encrypt_string, encrypt_key,iv);
$("#encrypt_key").text("JS加密密鑰:" +encrypt_key);
$("#encrypt_string").text("JS加密后字符串:" +encrypted_string);//********************************結束**********************************
//********************************解密**********************************
//解密密鑰16位(解密向量同上)
var decrypt_key = '20180227110419WB';//解密密文字符串
var decrypt_string = "8bkd/doBOrG3+pTEGkRwk9A3ZLrzXtf10E6Nn9CSoHXRXHydM7xt7PllPhUSItuK8ciF5g6UZ7DruCPQCVNZIJzI4ZHyUMJlV2aHyqMhbEoyS3pK6lPs1MsOeU/H7BZ5";var decrypted_string = decrypt(decrypt_string, decrypt_key,iv);
$("#decrypt_key").text("解密的密鑰(PHP端生成):" +decrypt_key);
$("#decrypt_string").text("JS解密后字符串:" +decrypted_string);//********************************結束**********************************
總結
以上是生活随笔為你收集整理的ss加密php,js前端加密,php后端解密(crypto-js,openssl_decrypt)的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: swift 拖动按钮_Swift - 单
- 下一篇: qt c++ 图片预览_Qt多语言国际化