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 相关文章推荐
JS 控制非法字符的输入代码
Dec 04 Javascript
jquery及原生js获取select下拉框选中的值示例
Oct 25 Javascript
js的Boolean对象初始值示例
Mar 04 Javascript
js控制网页前进和后退的方法
Jun 08 Javascript
基于javascript实现的快速排序
Dec 02 Javascript
JS遍历对象属性的方法示例
Jan 10 Javascript
JavaScript 函数的定义-调用、注意事项
Apr 16 Javascript
微信小程序--组件(swiper)详细介绍
Jun 13 Javascript
js + css实现标签内容切换功能(实例讲解)
Oct 09 Javascript
jsonp跨域获取数据的基础教程
Jul 01 Javascript
JS实现排行榜文字向上滚动轮播效果
Nov 26 Javascript
JS数据类型分类及常用判断方法
Nov 19 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
Netflix将与CLAMP、乙一以及冲方丁等6名知名制作人合伙展开原创动画计划!
2020/03/06 日漫
php设计模式 Delegation(委托模式)
2011/06/26 PHP
那些年一起学习的PHP(二)
2012/03/21 PHP
php有效防止同一用户多次登录
2015/11/19 PHP
PHP输入流php://input实例讲解
2015/12/22 PHP
PHP封装函数实现生成随机的字符串验证码
2017/01/24 PHP
javscript对象原型的一些看法
2010/09/19 Javascript
10个基于浏览器的JavaScript调试工具分享
2013/02/07 Javascript
jquery中radio checked问题
2015/03/16 Javascript
JavaScript实现自动对页面上敏感词进行屏蔽的方法
2015/07/27 Javascript
详解JavaScript ES6中的Generator
2015/07/28 Javascript
JavaScript深度复制(deep clone)的实现方法
2016/02/19 Javascript
JavaScript BASE64算法实现(完美解决中文乱码)
2017/01/10 Javascript
js实现下一页页码效果
2017/03/07 Javascript
推荐三款不错的图片压缩上传插件(webuploader、localResizeIMG4、LUploader)
2017/04/21 Javascript
解决vue与node模版引擎的渲染标记{{}}(双花括号)冲突问题
2020/09/11 Javascript
400多行Python代码实现了一个FTP服务器
2012/05/10 Python
Flask框架学习笔记(一)安装篇(windows安装与centos安装)
2014/06/25 Python
使用Python的判断语句模拟三目运算
2015/04/24 Python
Python运算符重载用法实例分析
2015/06/01 Python
Python Pandas 获取列匹配特定值的行的索引问题
2019/07/01 Python
keras读取训练好的模型参数并把参数赋值给其它模型详解
2020/06/15 Python
css3和jquery实现的可折叠导航菜单适合放在手机网页的导航菜单
2014/09/02 HTML / CSS
html5的canvas元素使用方法介绍(画矩形、画折线、圆形)
2014/04/14 HTML / CSS
美国鞋类购物网站:Shiekh Shoes
2016/08/21 全球购物
掌上明珠Java程序员面试总结
2016/02/23 面试题
外贸学院会计专业应届生求职信
2013/11/14 职场文书
幼儿园中班教师寄语
2014/04/03 职场文书
大学学生会竞选演讲稿
2014/04/25 职场文书
拓展策划方案
2014/06/03 职场文书
禁毒宣传标语
2014/06/19 职场文书
管理标语大全
2014/06/24 职场文书
团日活动总结格式
2015/05/11 职场文书
2015年图书馆个人工作总结
2015/05/26 职场文书
闭幕词的写作格式与范文!
2019/06/24 职场文书
解决Python字典查找报Keyerror的问题
2021/05/26 Python