這次帶給大家base64實作加密解密功能,base64實作加密解密功能的注意事項有哪些,以下就是實戰案例,一起來看一下。
關於加密,很多人想到encodeURI和escape。這個對加密url,尤其是帶有中文參數的url很有用。
如果只是想做加密解密,類似Java的DES,網路上jQuery有個jquery.base64.js。
(關於js的md5加密可以用jquery.md5.js,有興趣可以找測試一下)。
下面是測試:
<title></title> <meta> <script></script> <script></script> <input> <input> <br> <input> <br> 加密后:<input> <br> <input> <br> <br> <hr> <input> <br> 加密后:<input> <br> <input> <br> <br> <input> <br> <textarea></textarea> <script> varpath=document.getElementById("path").value; functionapp(info){ $("#txt").val($("#txt").val()+'\n'+info); } functionsubfunc(){ varput1=$.trim($("#putcardno01").val()); // var estxt=$.base64.encode(put1); //var estxt=$.base64.btoa(put1); varestxt=encodeBase64(put1); $("#putcardno02").val(estxt); app("加密后["+estxt+"]"); } functionsubfunc02(){ varput1=$.trim($("#putcardno02").val()); //var estxt=$.base64.decode(put1); //var estxt=$.base64.atob(put1); varestxt=decodeBase64(put1); app("解密后["+estxt+"]"); } ////////////////////////////////////////// varnumTimes=5; functionsubfunc03(){ varput1=$.trim($("#putcardno01").val()); // var estxt=$.base64.encode(put1); //var estxt=$.base64.btoa(put1); //estxt=$.base64.btoa(estxt); estxt=encodeBase64(put1,numTimes); $("#putcardno03").val(estxt); app(numTimes+"次加密后["+estxt+"]"); } functionsubfunc04(){ varput1=$.trim($("#putcardno03").val()); //var estxt=$.base64.decode(put1); //var estxt=$.base64.atob(put1); //estxt=$.base64.atob(estxt); estxt=decodeBase64(put1,numTimes); app(numTimes+"次解密后["+estxt+"]"); } functionclearrr(){ $("#putcardno02").val(""); $("#putcardno03").val(""); $("#putcardno04").val(""); $("#txt").val(""); } //加密方法。没有过滤首尾空格,即没有trim. //加密可以加密N次,对应解密N次就可以获取明文 functionencodeBase64(mingwen,times){ varcode=""; varnum=1; if(typeoftimes=='undefined'||times==null||times==""){ num=1; }else{ varvt=times+""; num=parseInt(vt); } if(typeofmingwen=='undefined'||mingwen==null||mingwen==""){ }else{ $.base64.utf8encode =true; code=mingwen; for(vari=0;i<num;i++){ code=$.base64.btoa(code); } } returncode; } //解密方法。没有过滤首尾空格,即没有trim //加密可以加密N次,对应解密N次就可以获取明文 functiondecodeBase64(mi,times){ varmingwen=""; varnum=1; if(typeoftimes=='undefined'||times==null||times==""){ num=1; }else{ varvt=times+""; num=parseInt(vt); } if(typeofmi=='undefined'||mi==null||mi==""){ }else{ $.base64.utf8encode =true; mingwen=mi; for(vari=0;i<num;i++){ mingwen=$.base64.atob(mingwen); } } returnmingwen; } /* 测试 输入 suolong2014version 加密后[c3VvbG9uZzIwMTR2ZXJzaW9u] 解密后[suolong2014version] 5次加密后[VjFod1QxWXlVblJUYTJoUVYwWmFhRnBYZEhOTk1WSlhWV3hPVG1KSVFscFZNalYzWVVaYU5tSkVSVDA9] 5次解密后[suolong2014version] */ </script>
在後台加密解密是不是跟前台一樣?
我們測試一下:
packagecom.code; importsun.misc.BASE64Decoder; importsun.misc.BASE64Encoder; /** * * Base64加密--解密 * * @author lushuaiyin * */ publicclassBase64Util { /** * @param args */ publicstaticvoidmain(String[] args) { // TODO Auto-generated method stub String str="suolong2014version"; System.out.println("测试明文["+str+"]"); String basecode =Base64Util.encodeBase64(str); System.out.println("加密后["+basecode+"]"); if(basecode!=null){ String res =Base64Util.decodeBase64(basecode); System.out.println("解密后["+res+"]"); } ///////////////////////////////////////// System.out.println(""); System.out.println("N次加密测试--------"); String basecodeN=Base64Util.encodeBase64(str,2); String resN=Base64Util.decodeBase64(basecodeN,2); String basecodeN3=Base64Util.encodeBase64(str,5); String resN3=Base64Util.decodeBase64(basecodeN3,5); } //提供加密N次 publicstaticString encodeBase64(String mingwen,inttimes){ intnum=(times<p style="text-align: left;"> 從結果來看,jquery.base64.js加密解密和java的base64加密解密是一樣的。 </p><p>相信看了本文案例你已經掌握了方法,更多精彩請關注php中文網其它相關文章! </p><p>推薦閱讀:</p><p><a href="http://www.php.cn/js-tutorial-393449.html" target="_blank">jQuery做出頁面遮罩層效果</a><br></p><p><a href="http://www.php.cn/js-tutorial-393438.html" target="_blank">#在jquery怎麼使用鍵盤事件</a><br></p><!--content end-->
以上是base64實現加密解密功能的詳細內容。更多資訊請關注PHP中文網其他相關文章!