位置: IT常识 - 正文

js常用的加密/解密方法(js加密解密源代码)

编辑:rootadmin
js常用的加密/解密方法 1.前言(老司机直接跳过) 为什么js需要加密

推荐整理分享js常用的加密/解密方法(js加密解密源代码),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:js加密后如何解密,js加密解密源代码,js 加密 解密,js 加密 解密,js 加密 解密,js加密后是如何运行的,js 加密 解密,js加解密方法,内容如对您有帮助,希望把文章链接给更多的朋友!

谈到加密,大多数人应用场景都在于后端接口的加密签名校验。这种一般都用于服务端与服务端之间的相互调用,避免第三方使用你的接口做违法违规的事情,这种加密校验比较安全,因为没有暴露在外的代码。

但是前端运行的JavaScript代码不一样,它是运行在浏览器的一种轻量级即时编译型的脚本语言。它是直接运行在用户电脑上的代码,除了在sojson.v6加密过的js代码,普通的js代码对于使用者来说是公开透明的,对于想要非法获取你的数据的人也是公开透明的,那么对于那些想要通过分析你的js代码来盗取你服务器数据的人来说,就是一件十分简单没难度的事情。

2.常用的js加密有哪些

JavaScript的原生函数escape()和unescape()

var code = 'console.log("hello")';var en = escape(code); // console.log%28%22hello%22%29var de = unescape(en); // console.log("hello")document.write(en, '     ', de)

用escape函数加密后,字符变成了%开头形式的特殊编码。

我们也可以用unescape把加密后的js解密回来

md5

https://github.com/blueimp/JavaScript-MD5

var hash = md5('value') // "2063c1608d6e0baf80249c42e2be5804"

MD5算法的原理可简要的叙述为:MD5码以512位分组来处理输入的信息,且每一分组又被划分为16个32位子分组,经过了一系列的处理后,算法的输出由四个32位分组组成,将这四个32位分组级联后将生成一个128位散列值。

md5加密一般用于确保文件和代码的唯一性,可以根据计算代码的md5值来判断代码是否被改变。

des/aes

https://github.com/brix/crypto-js

js常用的加密/解密方法(js加密解密源代码)

DES是一种使用密钥加密的块算法,1977年被美国联邦政府的国家标准局确定为联邦资料处理标准(FIPS),并授权在非密级政府通信中使用

1. 在utils/common.js中 写入公用的方法eg:// 公用方法 import CryptoJS from "../common/crypto-js/crypto-js.js" // 加密// 在main.js中引入export default { // 加密 encryptByDES(message, key) { const keyHex = CryptoJS.enc.Utf8.parse(key); const encrypted = CryptoJS.DES.encrypt(message, keyHex, { mode: CryptoJS.mode.ECB, padding: CryptoJS.pad.Pkcs7, }); return encrypted.toString(); }}2. 在main.js中引入import commonFun from './utils/common.js'//在 vue 的原型链 (prototype) 中注册Vue.prototype.$commonFun = commonFun3. 页面中使用this.$commonFun.encryptByDES(参数1, 参数2);//参数1:需要加密的数据//参数2:加密key

rsa

https://github.com/rzcoder/node-rsa

RSA是被研究得最广泛的公钥算法,从提出到现在已近三十年,经历了各种攻击的考验,逐渐为人们接受,普遍认为是目前最优秀的公钥方案之一。

const NodeRSA = require('node-rsa');const key = new NodeRSA({b: 512});const text = 'Hello RSA!';const encrypted = key.encrypt(text, 'base64');console.log('encrypted: ', encrypted);const decrypted = key.decrypt(encrypted, 'utf8');console.log('decrypted: ', decrypted);

base64

Base64是网络上最常见的用于传输8Bit字节码的编码方式之一,Base64就是一种基于64个可打印字符来表示二进制数据的方法

浏览器的window对象默认就有base64的加解密函数

const code = '(function(){ alert(\'hello\') }())'const en = window.btoa(code); // 加密const de = window.atob(en); // 解密

sha1

https://github.com/emn178/js-sha1

SHA1是一种密码散列函数,美国国家安全局设计,并由美国国家标准技术研究所(NIST)发布为联邦数据处理标准(FIPS)。SHA-1可以生成一个被称为消息摘要的160位(20字节)散列值,散列值通常的呈现形式为40个十六进制数。

sha1('Message to hash');var hash = sha1.create();hash.update('Message to hash');hash.hex();

sha256

https://github.com/emn178/js-sha256

SHA256是一种散列函数算法标准,由美国国家安全局研发,由美国国家标准与技术研究院(NIST)在2001年发布,属于SHA算法之一。和SHA1属于不同算法标准

sha256('Message to hash');sha224('Message to hash');var hash = sha256.create();hash.update('Message to hash');hash.hex();var hash2 = sha256.update('Message to hash');hash2.update('Message2 to hash');hash2.array();// HMACsha256.hmac('key', 'Message to hash');sha224.hmac('key', 'Message to hash');var hash = sha256.hmac.create('key');hash.update('Message to hash');hash.hex();var hash2 = sha256.hmac.update('key', 'Message to hash');hash2.update('Message2 to hash');hash2.array();

如果觉得上边这些加密方式还不够安全,无法达到你的预期,可以使用sojson.v6加密,加密强度在国内排名第一,作者每年都会更新加密算法,不停增加加密强度,既保证了js的运行速度又保证了js的安全性。

本文链接地址:https://www.jiuchutong.com/zhishi/297380.html 转载请保留说明!

上一篇:几个Linux杀死所有进程的方法(linux杀死程序)

下一篇:无需公网IP,远程连接SQL Server数据库【内网穿透】(没有公网ip如何实现外网访问路由器)

  • 所得税费用影响企业利润总额吗
  • 初级税务师什么时候报名
  • 验钞机怎么做账
  • 个体工商户必须缴纳社保吗
  • 打印机费用是属于管理费用吗
  • 资产负债表中本期盈余等于什么?
  • 利润表中第3栏营业税金及附加等于什么
  • 餐饮企业销售外购食品 增值税税率cpa
  • 个体工商户出租商铺个人所得税
  • 增值税专用发票可以开电子发票吗
  • 住宅小区共用部位有哪些
  • 临时工工资为什么那么低?
  • 以库存商品抵偿债务
  • 模具可以申请专利吗
  • 房屋租赁发票需要备注吗
  • 工程多少金额需要投标
  • 奖金用现金发放违法吗
  • 公司拖欠工资还要继续工作吗?
  • 增值税专票的收款人必须是个人嘛
  • 旅游业务开什么发票
  • 广告费定金属于什么科目
  • 怎么判断分红前已提取足够法定公积金?
  • 购进生产用原材料,取得增值税专用发票注明税额25600元
  • 单位外汇账户可分为
  • 零元股权转让会亏本吗
  • 期末留抵税额可以冲减欠税吗
  • 专家咨询费应如何支付
  • 代扣可以退款吗
  • 基本户是否可以冻结
  • 电脑找不到ie浏览器
  • linux 阿里云源
  • 法人向公司借款要交什么税
  • msoobe.exe是什么
  • PHP:Memcached::add()的用法_Memcached类
  • 辅导期一般纳税人可以抵扣进项吗
  • wirecut.exe
  • 文竹发黄怎么挽救?
  • frontpage在哪里打开
  • 直接转销法账务处理
  • vue ui怎么用
  • 房产土地税计提新规
  • php生成csv文件
  • 让渡资产使用权包含哪些内容
  • html游戏大全
  • 长期待摊费用是什么科目
  • 应付职工薪酬包括哪些二级科目
  • 应交增值税为负数怎么处理
  • 可供出售金融资产和交易性金融资产
  • 什么是合伙企业?它的特点有哪些?
  • 科目汇总表一张不够怎么写下一页
  • 租赁合同印花税怎么申报缴纳
  • 董事费收入
  • 耕地占用税通过税金及附加核算吗
  • 不抵扣勾选的发票在哪里查看
  • 个人所得税表格怎么做
  • 月底留抵税额需要结转吗
  • 增值税专用发票有几联?
  • 城建税退税分录怎么做
  • 其他债权投资的特征有哪些
  • 企业发生坏账损失时,在当期确认坏账损失
  • 房地产公司施工员
  • 听妈妈讲那过去的事情讲课
  • mysql 5.7.17 winx64安装配置方法图文教程
  • 极速一键装机
  • 如何知道文件的解压密码
  • 电脑win7在哪
  • win1020h2版本千万别更新
  • 删掉sam文件后无法开机
  • httpd: Could not determine the servers fully qualified domain name, using 127.0.
  • uibutton设置圆角
  • 表单元素的基本语法
  • js的点击事件怎么做
  • linux搭建ftp服务器
  • python常见的格式化输出小结
  • 跨浏览器插件
  • jquery中用onclick绑定点击事件
  • 季度申报怎么更正
  • 新都税务局咨询电话号码
  • 福建网上税务局app
  • 泉州市税务局投诉电话
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设