国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > JavaScript > 正文

jQuery實現base64前臺加密解密功能詳解

2019-11-19 15:38:42
字體:
來源:轉載
供稿:網友

本文實例講述了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次后[VjFod1QxWXlVblJUYTJoUVYwWmFhRnBYZEhOTk1WSlhWV3hPVG1KSVFscFZNalYzWVVaYU5tSkVSVDA9]解密5次后[suolong2014version]*/

從結果上看,jquery.base64.js加密解密和java的base64加密解密是一樣的。

PS:這里再推薦幾款加密解密相關在線工具供大家參考使用:

線編碼轉換工具(utf-8/utf-32/Punycode/Base64):
http://tools.VeVB.COm/transcoding/decode_encode_tool

BASE64編碼解碼工具:
http://tools.VeVB.COm/transcoding/base64

圖片轉換為Base64編碼在線工具:
http://tools.VeVB.COm/transcoding/img2base64

在線MD5/hash/SHA-1/SHA-2/SHA-256/SHA-512/SHA-3/RIPEMD-160加密工具:
http://tools.VeVB.COm/password/hash_md5_sha

更多關于jQuery相關內容感興趣的讀者可查看本站專題:《jQuery常用插件及用法總結》、《jQuery擴展技巧總結》、《jQuery切換特效與技巧總結》、《jQuery遍歷算法與技巧總結》、《jQuery常見經典特效匯總》及《jquery選擇器用法總結

希望本文所述對大家jQuery程序設計有所幫助。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 昌图县| 富顺县| 清流县| 金平| 法库县| 延津县| 合肥市| 满城县| 天全县| 富蕴县| 佛山市| 阿拉善盟| 尼木县| 五华县| 邯郸县| 河源市| 章丘市| 宜春市| 上蔡县| 龙山县| 双桥区| 南部县| 临武县| 黎川县| 滦南县| 恩施市| 临安市| 三河市| 长宁区| 江华| 荔浦县| 轮台县| 肥城市| 镇巴县| 建昌县| 漾濞| 岗巴县| 毕节市| 株洲市| 儋州市| 哈尔滨市|