jquery加密java解密_jQuery实现base64前台加密解密功能详解

本文实例讲述了jQuery实现base64前台加密解密功能。分享给大家供大家参考,具体如下:

关于加密,很多人想到encodeURI和escape。这个对加密url,尤其是带中文参数的url很有用。

如果只是想做加密解密,类似于Java的DES,网上jQuery有个jquery.base64.js。

(关于js的md5加密可以用jquery.md5.js,有兴趣可以找来测试一下)。

下面是测试:

加密后:


加密后:

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

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

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

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

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

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:这里再推荐几款加密解密相关在线工具供大家参考使用:

在线MD5/hash/SHA-1/SHA-2/SHA-256/SHA-512/SHA-3/RIPEMD-160加密工具:http://tools.jb51.net/password/hash_md5_sha

希望本文所述对大家jQuery程序设计有所帮助。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
首先说明一下,btoa和atob是JavaScript自带的Base64编码和解码函数,它们的作用是将字符串转换为Base64编码格式或将Base64编码格式的字符串转换为普通字符串。 在JavaScript中,如果要使用btoa函数进行Base64编码,可以这样写: ```javascript var str = "Hello, world!"; var base64 = btoa(str); console.log(base64); // "SGVsbG8sIHdvcmxkIQ==" ``` 如果要使用atob函数进行Base64解码,可以这样写: ```javascript var base64 = "SGVsbG8sIHdvcmxkIQ=="; var str = atob(base64); console.log(str); // "Hello, world!" ``` 在PHP中,可以使用base64_encode和base64_decode函数来对Base64编码和解码。对于上面的例子,可以这样写: ```php $base64 = "SGVsbG8sIHdvcmxkIQ=="; $str = base64_decode($base64); echo $str; // "Hello, world!" ``` 如果要在jQuery实现前台Base64加密解密功能,可以使用JavaScript自带的btoa和atob函数,也可以使用第三方的Base64库。具体实现可以参考以下代码: ```javascript // 加密 var str = "Hello, world!"; var base64 = btoa(str); console.log(base64); // "SGVsbG8sIHdvcmxkIQ==" // 解密 var base64 = "SGVsbG8sIHdvcmxkIQ=="; var str = atob(base64); console.log(str); // "Hello, world!" // 使用第三方库进行加密解密 var str = "Hello, world!"; var base64 = $.base64.encode(str); console.log(base64); // "SGVsbG8sIHdvcmxkIQ==" var str = $.base64.decode(base64); console.log(str); // "Hello, world!" ``` 需要注意的是,前台Base64加密解密只能防止一些简单的攻击,对于敏感数据仍然需要使用HTTPS等安全协议进行传输。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值