当前位置: 移动技术网 > IT编程>开发语言>JavaScript > jQuery实现base64前台加密解密功能详解

jQuery实现base64前台加密解密功能详解

2017年12月12日  | 移动技术网IT编程  | 我要评论
本文实例讲述了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程序设计有所帮助。

如您对本文有疑问或者有任何想说的,请 点击进行留言回复,万千网友为您解惑!

相关文章:

验证码:
移动技术网