網頁端(在沒有https情況下)給密碼之類的加密傳輸,雖然多此一舉,也好過直接監控軟件就能看到密碼
在傳輸密碼的時候,先向后臺獲取一個隨機碼或者驗證碼,作為秘鑰,網頁端根據這個秘鑰,加密要傳輸的數據,服務端先驗證驗證碼是否正確,如果驗證正確,根據驗證碼進行數據解密 fox.風
下載地址: 1.https://code.google.com/archive/p/crypto-js/downloads2.https://github.com/brix/crypto-js/tree/release-3.1.2 (build 目錄下)先加載js文件
<script src="crypto-js/rollups/aes.js" type="text/javascript"></script><script src="crypto-js/rollups/md5.js" type="text/Javascript"></script><script src="crypto-js/components/pad-zeropadding-min.js" type="text/javascript"></script>/** * 加密 */function encrypt(str,key) { key = CryptoJS.enc.Utf8.parse(key?key:"1111111111111111");// 秘鑰 var iv= CryptoJS.enc.Utf8.parse('1234567890123412');//向量iv var encrypted = CryptoJS.AES.encrypt(str, key, { iv: iv, mode: CryptoJS.mode.CBC, padding: CryptoJS.pad.ZeroPadding }); return encrypted.toString();}/** * 解密 * @param str */function decrypt(str) { var key = CryptoJS.enc.Utf8.parse("1111111111111111");// 秘鑰 var iv= CryptoJS.enc.Utf8.parse('1234567890123412');//向量iv var decrypted = CryptoJS.AES.decrypt(str,key,{iv:iv,padding:CryptoJS.pad.ZeroPadding}); return decrypted.toString(CryptoJS.enc.Utf8);}//調用//加密console.log(encrypt("12345"));//解密console.log(decrypt("待解密字符"));實際使用
JS
//加密部分要改造一下/** * 加密 */function encrypt(str,key) { key = CryptoJS.enc.Utf8.parse(CryptoJS.MD5(key).toString());//秘鑰 var iv= CryptoJS.enc.Utf8.parse('1234567890123412');//向量iv var encrypted = CryptoJS.AES.encrypt(str, key, { iv: iv, mode: CryptoJS.mode.CBC, padding: CryptoJS.pad.ZeroPadding }); return encrypted.toString();}//驗證碼 轉換成大寫var username=$('#username').val();//獲取用戶名var pwd=$('#pwd').val();//獲取密碼var verify=$('#verify').val();//獲取驗證碼verify = verify.toUpperCase();var json = {username: username, pwd: pwd};//被加密的數據var aes = encrypt(JSON.stringify(json), verify);//加密var param = {verify: verify, param: aes};$.post("/user/login?_=" + new Date().getTime(), param, function (data) { if (data) { ... } else { .... }}, "json");PHP$verify=input('verify');//驗證碼$param=input('param');//加密后數據//先轉換成大寫//然后MD5$json=AesJs::decrypt($param,md5(strtoupper($verify)));echo $json;$arr=json_decode($json,true);print_r($arr);來源http://blog.csdn.net/momo_mutou/article/details/44240371
新聞熱點
疑難解答
圖片精選