JS实现的base64加密解密操作示例


Posted in Javascript onApril 18, 2018

本文实例讲述了JS实现的base64加密解密操作。分享给大家供大家参考,具体如下:

<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8" />
<title>js base64加密解密</title>
</head>
<body>
<script>
// 创建Base64对象
var Base64 = {
 _keyStr: "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=",
 encode: function(e) {
  var t = "";
  var n, r, i, s, o, u, a;
  var f = 0;
  e = Base64._utf8_encode(e);
  while (f < e.length) {
   n = e.charCodeAt(f++);
   r = e.charCodeAt(f++);
   i = e.charCodeAt(f++);
   s = n >> 2;
   o = (n & 3) << 4 | r >> 4;
   u = (r & 15) << 2 | i >> 6;
   a = i & 63;
   if (isNaN(r)) {
    u = a = 64
   } else if (isNaN(i)) {
    a = 64
   }
   t = t + this._keyStr.charAt(s) + this._keyStr.charAt(o) + this._keyStr.charAt(u) + this._keyStr.charAt(a)
  }
  return t
 },
 decode: function(e) {
  var t = "";
  var n, r, i;
  var s, o, u, a;
  var f = 0;
  e=e.replace(/[^A-Za-z0-9+/=]/g,"");
  while (f < e.length) {
   s = this._keyStr.indexOf(e.charAt(f++));
   o = this._keyStr.indexOf(e.charAt(f++));
   u = this._keyStr.indexOf(e.charAt(f++));
   a = this._keyStr.indexOf(e.charAt(f++));
   n = s << 2 | o >> 4;
   r = (o & 15) << 4 | u >> 2;
   i = (u & 3) << 6 | a;
   t = t + String.fromCharCode(n);
   if (u != 64) {
    t = t + String.fromCharCode(r)
   }
   if (a != 64) {
    t = t + String.fromCharCode(i)
   }
  }
  t = Base64._utf8_decode(t);
  return t
 },
 _utf8_encode: function(e) {
  e = e.replace(/rn/g, "n");
  var t = "";
  for (var n = 0; n < e.length; n++) {
   var r = e.charCodeAt(n);
   if (r < 128) {
    t += String.fromCharCode(r)
   } else if (r > 127 && r < 2048) {
    t += String.fromCharCode(r >> 6 | 192);
    t += String.fromCharCode(r & 63 | 128)
   } else {
    t += String.fromCharCode(r >> 12 | 224);
    t += String.fromCharCode(r >> 6 & 63 | 128);
    t += String.fromCharCode(r & 63 | 128)
   }
  }
  return t
 },
 _utf8_decode: function(e) {
  var t = "";
  var n = 0;
  var r = c1 = c2 = 0;
  while (n < e.length) {
   r = e.charCodeAt(n);
   if (r < 128) {
    t += String.fromCharCode(r);
    n++
   } else if (r > 191 && r < 224) {
    c2 = e.charCodeAt(n + 1);
    t += String.fromCharCode((r & 31) << 6 | c2 & 63);
    n += 2
   } else {
    c2 = e.charCodeAt(n + 1);
    c3 = e.charCodeAt(n + 2);
    t += String.fromCharCode((r & 15) << 12 | (c2 & 63) << 6 | c3 & 63);
    n += 3
   }
  }
  return t
 }
}
// 定义字符串
var string = 'Hello World!';
// 加密
var encodedString = Base64.encode(string);
console.log(encodedString); // 输出: "SGVsbG8gV29ybGQh"
// 解密
var decodedString = Base64.decode(encodedString);
console.log(decodedString); // 输出: "Hello World!"
</script>
</body>
</html>

运行结果:

JS实现的base64加密解密操作示例

Javascript 相关文章推荐
javascript 用原型继承来实现对象系统
Mar 22 Javascript
JavaScript去掉空格的方法集合
Dec 28 Javascript
js去除输入框中所有的空格和禁止输入空格的方法
Jun 09 Javascript
jQuery修改li下的样式以及li下的img的src的值的方法
Nov 02 Javascript
js完美解决IE6不支持position:fixed的bug
Apr 24 Javascript
js对字符串进行编码的方法总结(推荐)
Nov 10 Javascript
在js中做数字字符串补0(js补零)
Mar 25 Javascript
Node.JS文件系统解析实例详解
May 15 Javascript
深入理解Vue transition源码分析
Jul 30 Javascript
AngularJS双向数据绑定原理之$watch、$apply和$digest的应用
Jan 30 Javascript
浅谈Vue页面级缓存解决方案feb-alive(上)
Apr 14 Javascript
详解Vue中的Props与Data细微差别
Mar 02 Javascript
JS实现简单获取最近7天和最近3天日期的方法
Apr 18 #Javascript
详解Node使用Puppeteer完成一次复杂的爬虫
Apr 18 #Javascript
jQuery滚动条美化插件nicescroll简单用法示例
Apr 18 #jQuery
Angular 如何使用第三方库的方法
Apr 18 #Javascript
jQuery实现的淡入淡出与滑入滑出效果示例
Apr 18 #jQuery
浅谈mvvm-simple双向绑定简单实现
Apr 18 #Javascript
JS点击动态添加标签、删除指定标签的代码
Apr 18 #Javascript
You might like
几款免费开源的不用数据库的php的cms
2010/12/19 PHP
PHP删除非空目录的函数代码小结
2013/02/28 PHP
phpnow php探针环境检测代码
2014/11/04 PHP
各种常用浏览器getBoundingClientRect的解析
2009/05/21 Javascript
javascript与asp.net(c#)互相调用方法
2009/12/13 Javascript
jquery下json数组的操作实现代码
2010/08/09 Javascript
模拟jQuery中的ready方法及实现按需加载css,js实例代码
2013/09/27 Javascript
JavaScript图片放大技术(放大镜)实现代码分享
2013/11/14 Javascript
JS获取客户端IP地址、MAC和主机名的7个方法汇总
2014/07/21 Javascript
上传图片预览JS脚本 Input file图片预览的实现示例
2014/10/23 Javascript
JavaScript实现函数返回多个值的方法
2015/06/09 Javascript
javascript正则表达式定义(语法)总结
2016/01/08 Javascript
JS基于构造函数实现的菜单滑动显隐效果【测试可用】
2016/06/21 Javascript
老生常谈jquery中detach()和remove()的区别
2017/03/02 Javascript
利用node.js本地搭建HTTP服务器
2017/04/19 Javascript
Vue中的混入的使用(vue mixins)
2018/06/01 Javascript
Vue实现本地购物车功能
2018/12/05 Javascript
JS学习笔记之闭包小案例分析
2019/05/29 Javascript
[50:21]Liquid vs Winstrike 2018国际邀请赛小组赛BO2 第二场
2018/08/19 DOTA
将Python的Django框架与认证系统整合的方法
2015/07/24 Python
python中利用await关键字如何等待Future对象完成详解
2017/09/07 Python
python数据结构之列表和元组的详解
2017/09/23 Python
对pandas中Series的map函数详解
2018/07/25 Python
selenium+python设置爬虫代理IP的方法
2018/11/29 Python
pytorch实现用Resnet提取特征并保存为txt文件的方法
2019/08/20 Python
python中requests模拟登录的三种方式(携带cookie/session进行请求网站)
2020/11/17 Python
xml有哪些解析技术?区别是什么
2016/04/26 面试题
北京银河万佳Java面试题
2012/03/21 面试题
生产经理的自我评价分享
2013/11/07 职场文书
全国助残日活动总结
2015/05/11 职场文书
golang如何去除多余空白字符(含制表符)
2021/04/25 Golang
JDBC连接的六步实例代码(与mysql连接)
2021/05/12 MySQL
教你使用pyinstaller打包Python教程
2021/05/27 Python
python字典进行运算原理及实例分享
2021/08/02 Python
Python Matplotlib绘制等高线图与渐变色扇形图
2022/04/14 Python
Python中的socket网络模块介绍
2022/07/23 Python