jQuery--base64前台加密解密

varpath=document.getElementById("path").value;

function app(info){

$("#txt").val($("#txt").val()+'\n'+info);

}

function subfunc(){

varput1=$.trim($("#putcardno01").val());

// varestxt=$.base64.encode(put1);

//varestxt=$.base64.btoa(put1);

varestxt=encodeBase64(put1);

$("#putcardno02").val(estxt);

app("加密后["+estxt+"]");

}

function subfunc02(){

varput1=$.trim($("#putcardno02").val());

//varestxt=$.base64.decode(put1);

//varestxt=$.base64.atob(put1);

varestxt=decodeBase64(put1);

app("解密后["+estxt+"]");

}

//////////////////////////////////////////

varnumTimes=5;

function subfunc03(){

varput1=$.trim($("#putcardno01").val());

// varestxt=$.base64.encode(put1);

//varestxt=$.base64.btoa(put1);

//estxt=$.base64.btoa(estxt);

estxt=encodeBase64(put1,numTimes);

$("#putcardno03").val(estxt);

app(numTimes+"次加密后["+estxt+"]");

}

function subfunc04(){

varput1=$.trim($("#putcardno03").val());

//varestxt=$.base64.decode(put1);

//varestxt=$.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){

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

code=$.base64.btoa(code);

}

}

return code;

}

//解密方法。没有过滤首尾空格,即没有trim

//加密可以加密N次,对应解密N次就可以获取明文

function decodeBase64(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

mingwen=$.base64.atob(mingwen);

}

}

return mingwen;

}

/*

测试

输入 suolong2014version

加密后[c3VvbG9uZzIwMTR2ZXJzaW9u]

解密后[suolong2014version]

5次加密后[VjFod1QxWXlVblJUYTJoUVYwWmFhRnBYZEhOTk1WSlhWV3hPVG1KSVFscFZNalYzWVVaYU5tSkVSVDA9]

5次解密后[suolong2014version]

*/





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

Stringstr="suolong2014version";

System.out.println("测试明文["+str+"]");

Stringbasecode=Base64Util.encodeBase64(str);

System.out.println("加密后["+basecode+"]");

if(basecode!=null){

Stringres=Base64Util.decodeBase64(basecode);

System.out.println("解密后["+res+"]");

}

/////////////////////////////////////////

System.out.println("");

System.out.println("N次加密测试--------");

StringbasecodeN=Base64Util.encodeBase64(str, 2);

StringresN=Base64Util.decodeBase64(basecodeN, 2);

StringbasecodeN3=Base64Util.encodeBase64(str, 5);

StringresN3=Base64Util.decodeBase64(basecodeN3, 5);

}

//提供加密N次

public static String encodeBase64(String mingwen,int times){

intnum=(times<=0)?1:times;

Stringcode="";

if(mingwen==null||mingwen.equals("")){

}else{

code=mingwen;

for(inti=0;i

code=encodeBase64(code);

}

System.out.println("加密"+num+"次后["+code+"]");

}

return code;

}

//对应提供解密N次

public static String decodeBase64(String mi,int times){

intnum=(times<=0)?1:times;

Stringmingwen="";

if(mi==null||mi.equals("")){

}else{

mingwen=mi;

for(inti=0;i

mingwen=decodeBase64(mingwen);

}

System.out.println("解密"+num+"次后["+mingwen+"]");

}

return mingwen;

}

///////////////////////////////////////////////////////////////////

public static String encodeBase64(String mingwen){

Stringcode="";

if(mingwen==null||mingwen.equals("")){

}else{

BASE64Encoderencoder=newBASE64Encoder();

try {

code=encoder.encode(mingwen.getBytes());

} catch (Exception e) {

e.printStackTrace();

}

//          System.out.println("加密后["+code+"]");

}

return code;

}

public static String decodeBase64(String mi){

Stringmingwen="";

if(mi==null||mi.equals("")){

}else{

BASE64Decoderdecoder=newBASE64Decoder();

try {

byte[]by=decoder.decodeBuffer(mi);

mingwen=newString(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]

*/



转发自http://blog.csdn.net/lushuaiyin/article/details/26581231

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 1. Java基础部分 基础部分的顺序:基本语法,类相关的语法,内部类的语法,继承相关的语法,异常的语法,线程的语...
    子非鱼_t_阅读 31,958评论 18 399
  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 135,518评论 19 139
  • 概述 之前一直对加密相关的算法知之甚少,只知道类似DES、RSA等加密算法能对数据传输进行加密,且各种加密算法各有...
    Henryzhu阅读 8,195评论 0 14
  • 昨天晚上老公回家,告诉我一个坏消息。从下周起他要每周出差三天,想想都觉得很崩溃。好绝望。自从有了宝宝,日子变得不再...
    花树123阅读 1,046评论 0 0
  • 一,奇迹 1.早晨起来就到小区进行动态静心运动,真好,美丽的小区环境,还摘了几个莲蓬,美味极了!美丽的心情是常态!...
    富足的凤娇云儿阅读 1,638评论 0 0