jQuery实现base64前台加密解密功能详解
程序员文章站
2022-09-08 22:06:20
本文实例讲述了jquery实现base64前台加密解密功能。分享给大家供大家参考,具体如下:
关于加密,很多人想到encodeuri和escape。这个对加密url,尤其...
本文实例讲述了jquery实现base64前台加密解密功能。分享给大家供大家参考,具体如下:
关于加密,很多人想到encodeuri和escape。这个对加密url,尤其是带中文参数的url很有用。
如果只是想做加密解密,类似于java的des,网上jquery有个jquery.base64.js。
(关于js的md5加密可以用jquery.md5.js,有兴趣可以找来测试一下)。
下面是测试:
<html> <head> <title></title> <meta http-equiv="content-type" content="text/html; charset=utf-8"> <script language="javascript" src="jquery-1.7.1.js"></script> <script language="javascript" src="jquery.base64.js"></script> </head> <body> <input id="path" name="path" type="hidden" value="haha"></input> <input id="putcardno01" name="putcardno01" type="text" size="65" value=""></input> <br> <input onclick="subfunc();" class="btn1" value="提交加密" type="button"></input> <br> 加密后:<input id="putcardno02" name="putcardno02" type="text" size="65" value=""></input> <br> <input onclick="subfunc02();" class="btn1" value="提交解密" type="button"></input> <br> <br> <hr> <input onclick="subfunc03();" class="btn1" value="提交n次加密" type="button"></input> <br> 加密后:<input id="putcardno03" name="putcardno03" type="text" size="65" value=""></input> <br> <input onclick="subfunc04();" class="btn1" value="提交n次解密" type="button"></input> <br> <br> <input onclick="clearrr();" class="btn1" value="清除" type="button"></input> <br> <textarea id='txt' cols="75" rows="19"></textarea> </body> <script language="javascript"> var path=document.getelementbyid("path").value; function app(info){ $("#txt").val($("#txt").val()+'\n'+info); } function subfunc(){ var put1=$.trim($("#putcardno01").val()); // var estxt=$.base64.encode(put1); //var estxt=$.base64.btoa(put1); var estxt=encodebase64(put1); $("#putcardno02").val(estxt); app("加密后["+estxt+"]"); } function subfunc02(){ var put1=$.trim($("#putcardno02").val()); //var estxt=$.base64.decode(put1); //var estxt=$.base64.atob(put1); var estxt=decodebase64(put1); app("解密后["+estxt+"]"); } ////////////////////////////////////////// var numtimes=5; function subfunc03(){ var put1=$.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+"]"); } function subfunc04(){ var put1=$.trim($("#putcardno03").val()); //var estxt=$.base64.decode(put1); //var estxt=$.base64.atob(put1); //estxt=$.base64.atob(estxt); estxt=decodebase64(put1,numtimes); app(numtimes+"次解密后["+estxt+"]"); } function clearrr(){ $("#putcardno02").val(""); $("#putcardno03").val(""); $("#putcardno04").val(""); $("#txt").val(""); } //加密方法。没有过滤首尾空格,即没有trim. //加密可以加密n次,对应解密n次就可以获取明文 function encodebase64(mingwen,times){ var code=""; var num=1; if(typeof times=='undefined'||times==null||times==""){ num=1; }else{ var vt=times+""; num=parseint(vt); } if(typeof mingwen=='undefined'||mingwen==null||mingwen==""){ }else{ $.base64.utf8encode = true; code=mingwen; for(var i=0;i<num;i++){ code=$.base64.btoa(code); } } return code; } //解密方法。没有过滤首尾空格,即没有trim //加密可以加密n次,对应解密n次就可以获取明文 function decodebase64(mi,times){ var mingwen=""; var num=1; if(typeof times=='undefined'||times==null||times==""){ num=1; }else{ var vt=times+""; num=parseint(vt); } if(typeof mi=='undefined'||mi==null||mi==""){ }else{ $.base64.utf8encode = true; mingwen=mi; for(var i=0;i<num;i++){ mingwen=$.base64.atob(mingwen); } } return mingwen; } /* 测试 输入 suolong2014version 加密后[c3vvbg9uzziwmtr2zxjzaw9u] 解密后[suolong2014version] 5次加密后[vjfod1qxwxlvbljuytjouvywwmfhrnbyzehotk1wslhwv3hpvg1ksvfscfznalyzwvvayu5tskvsvda9] 5次解密后[suolong2014version] */ </script>
在后台加密解密是不是和前台一样?
我们测试一下:
package com.code; import sun.misc.base64decoder; import sun.misc.base64encoder; /** * * base64加密--解密 * * @author lushuaiyin * */ public class base64util { /** * @param args */ public static void main(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次 public static string encodebase64(string mingwen,int times){ int num=(times<=0)?1:times; string code=""; if(mingwen==null||mingwen.equals("")){ }else{ code=mingwen; for(int i=0;i<num;i++){ code=encodebase64(code); } system.out.println("加密"+num+"次后["+code+"]"); } return code; } //对应提供解密n次 public static string decodebase64(string mi,int times){ int num=(times<=0)?1:times; string mingwen=""; if(mi==null||mi.equals("")){ }else{ mingwen=mi; for(int i=0;i<num;i++){ mingwen=decodebase64(mingwen); } system.out.println("解密"+num+"次后["+mingwen+"]"); } return mingwen; } /////////////////////////////////////////////////////////////////// public static string encodebase64(string mingwen){ string code=""; if(mingwen==null||mingwen.equals("")){ }else{ base64encoder encoder = new base64encoder(); try { code=encoder.encode(mingwen.getbytes()); } catch (exception e) { e.printstacktrace(); } // system.out.println("加密后["+code+"]"); } return code; } public static string decodebase64(string mi){ string mingwen=""; if(mi==null||mi.equals("")){ }else{ base64decoder decoder = new base64decoder(); try { byte[] by = decoder.decodebuffer(mi); mingwen = new string(by); } catch (exception e) { e.printstacktrace(); } // system.out.println("解密后["+mingwen+"]"); } return mingwen; } } /* 打印: 测试明文[suolong2014version] 加密后[c3vvbg9uzziwmtr2zxjzaw9u] 解密后[suolong2014version] n次加密测试-------- 加密2次后[yznwdmjhoxvaekl3tvrsmlpysnphvzl1] 解密2次后[suolong2014version] 加密5次后[vjfod1qxwxlvbljuytjouvywwmfhrnbyzehotk1wslhwv3hpvg1ksvfscfznalyzwvvayu5tskvs vda9] 解密5次后[suolong2014version] */
从结果上看,jquery.base64.js加密解密和java的base64加密解密是一样的。
ps:这里再推荐几款加密解密相关在线工具供大家参考使用:
线编码转换工具(utf-8/utf-32/punycode/base64):
base64编码解码工具:
图片转换为base64编码在线工具:
在线md5/hash/sha-1/sha-2/sha-256/sha-512/sha-3/ripemd-160加密工具:
更多关于jquery相关内容感兴趣的读者可查看本站专题:《jquery常用插件及用法总结》、《jquery扩展技巧总结》、《jquery切换特效与技巧总结》、《jquery遍历算法与技巧总结》、《jquery常见经典特效汇总》及《jquery选择器用法总结》
希望本文所述对大家jquery程序设计有所帮助。