jQuery实现base64前台加密解密功能详解
发布时间 - 2026-01-11 03:00:41 点击率:次本文实例讲述了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):
http://tools./transcoding/decode_encode_tool
BASE64编码解码工具:
http://tools./transcoding/base64
图片转换为Base64编码在线工具:
http://tools./transcoding/img2base64
在线MD5/hash/SHA-1/SHA-2/SHA-256/SHA-512/SHA-3/RIPEMD-160加密工具:
http://tools./password/hash_md5_sha
更多关于jQuery相关内容感兴趣的读者可查看本站专题:《jQuery常用插件及用法总结》、《jQuery扩展技巧总结》、《jQuery切换特效与技巧总结》、《jQuery遍历算法与技巧总结》、《jQuery常见经典特效汇总》及《jquery选择器用法总结》
希望本文所述对大家jQuery程序设计有所帮助。
# jQuery
# base64
# 前台
# 加密
# 解密
# JMeter导入自定义的Jar包的详解教程
# java自定义jar包让jmeter使用的方法
# java使用Base64实现文件加密解密
# python3.x实现base64加密和解密
# JS加密插件CryptoJS实现的Base64加密示例
# JS实现的3des+base64加密解密算法完整示例
# JS实现的base64加密解密操作示例
# Jmeter自定义函数base64加密实现过程解析
# 加密解密
# 就可以
# 测试一下
# 相关内容
# 有个
# 尤其是
# 很多人
# 可以用
# 遍历
# 感兴趣
# 给大家
# 有兴趣
# 上看
# 想做
# 更多关于
# 类似于
# 找来
# 转换为
# 所述
# 几款
相关栏目:
【
网站优化151355 】
【
网络推广146373 】
【
网络技术251813 】
【
AI营销90571 】
相关推荐:
javascript基本数据类型及类型检测常用方法小结
ChatGPT怎么生成Excel公式_ChatGPT公式生成方法【指南】
瓜子二手车官方网站在线入口 瓜子二手车网页版官网通道入口
如何使用 jQuery 正确渲染 Instagram 风格的标签列表
PHP 500报错的快速解决方法
如何用VPS主机快速搭建个人网站?
Mybatis 中的insertOrUpdate操作
CSS3怎么给轮播图加过渡动画_transition加transform实现【技巧】
Laravel如何使用API Resources格式化JSON响应_Laravel数据资源封装与格式化输出
详解Android中Activity的四大启动模式实验简述
清除minerd进程的简单方法
标题:Vue + Vuex 项目中正确使用 JWT 进行身份认证的实践指南
韩国服务器如何优化跨境访问实现高效连接?
深圳防火门网站制作公司,深圳中天明防火门怎么编码?
北京网站制作的公司有哪些,北京白云观官方网站?
公司网站制作价格怎么算,公司办个官网需要多少钱?
怎么制作一个起泡网,水泡粪全漏粪育肥舍冬季氨气超过25ppm,可以有哪些措施降低舍内氨气水平?
UC浏览器如何切换小说阅读源_UC浏览器阅读源切换【方法】
海南网站制作公司有哪些,海口网是哪家的?
如何在阿里云ECS服务器部署织梦CMS网站?
制作旅游网站html,怎样注册旅游网站?
HTML透明颜色代码在Angular里怎么设置_Angular透明颜色使用指南【详解】
Linux安全能力提升路径_长期防护思维说明【指导】
深入理解Android中的xmlns:tools属性
Angular 表单中正确绑定输入值以确保提交与验证正常工作
电商网站制作多少钱一个,电子商务公司的网站制作费用计入什么科目?
如何用搬瓦工VPS快速搭建个人网站?
消息称 OpenAI 正研发的神秘硬件设备或为智能笔,富士康代工
Laravel Asset编译怎么配置_Laravel Vite前端构建工具使用
哪家制作企业网站好,开办像阿里巴巴那样的网络公司和网站要怎么做?
手机软键盘弹出时影响布局的解决方法
JavaScript常见的五种数组去重的方式
laravel怎么为API路由添加签名中间件保护_laravel API路由签名中间件保护方法
移动端手机网站制作软件,掌上时代,移动端网站的谷歌SEO该如何做?
如何为不同团队 ID 动态生成多个独立按钮
Laravel Eloquent模型如何创建_Laravel ORM基础之Model创建与使用教程
Laravel Seeder填充数据教程_Laravel模型工厂Factory使用
Laravel如何部署到服务器_线上部署Laravel项目的完整流程与步骤
如何选择PHP开源工具快速搭建网站?
如何在景安云服务器上绑定域名并配置虚拟主机?
Laravel的辅助函数有哪些_Laravel常用Helpers函数提高开发效率
Laravel观察者模式如何使用_Laravel Model Observer配置
如何快速查询网站的真实建站时间?
如何做网站制作流程,*游戏网站怎么搭建?
网站制作企业,网站的banner和导航栏是指什么?
如何自定义建站之星模板颜色并下载新样式?
高端智能建站公司优选:品牌定制与SEO优化一站式服务
jQuery validate插件功能与用法详解
详解ASP.NET 生成二维码实例(采用ThoughtWorks.QRCode和QrCode.Net两种方式)
车管所网站制作流程,交警当场开简易程序处罚决定书,在交警网站查询不到怎么办?

