记录-JavaScript常规加密技术

这里给大家分享我在网上总结出来的一些知识,希望对大家有所帮助

记录-JavaScript常规加密技术

当今Web开发中,数据安全是一个至关重要的问题,为了确保数据的安全性,我们需要使用加密技术。JavaScript作为一种客户端编程语言,可以很好地为数据进行加密。在本篇文章中,我们将为你提供一个常规JavaScript加密大全,以及案例代码来演示如何使用它们。

Base64加密

Base64是一种将二进制数据编码为ASCII字符的编码方式。这种编码方式广泛应用于将二进制数据转换为文本数据的场合,例如在电子邮件中传输二进制数据。以下是JavaScript实现Base64加密的代码:

function base64Encode(str) {
  return btoa(encodeURIComponent(str).replace(/%([0-9A-F]{2})/g, (match, p1) => String.fromCharCode('0x' + p1)));
}

这里我们使用了JavaScript内置的btoa()函数和encodeURIComponent()函数。其中,btoa()函数可以将字符串编码为Base64格式,而encodeURIComponent()函数则可以将字符串转换为可传输的URI格式。我们还使用了一个正则表达式来将URI格式中的特殊字符进行替换。最后,我们将处理后的字符串返回作为结果。

以下是一个使用Base64加密的例子:

const originalString = "Hello, world!";
const encodedString = base64Encode(originalString);
​
console.log("Original string:", originalString);
console.log("Encoded string:", encodedString);

运行上述代码,输出将会是:

Original string: Hello, world!
Encoded string: SGVsbG8sIHdvcmxkIQ==

MD5加密

MD5是一种广泛使用的消息摘要算法,用于验证数据完整性和防止数据被篡改。MD5生成的摘要信息是一个128位的二进制数据,通常表示为32个十六进制数字。以下是JavaScript实现MD5加密的代码:

function md5(str) {
  let md5Hash = CryptoJS.MD5(str);
  return md5Hash.toString(CryptoJS.enc.Hex);
}

在这里,我们使用了一个JavaScript库CryptoJS来实现MD5加密。我们首先将输入的字符串传递给CryptoJS.MD5()函数进行摘要计算,然后将结果转换为十六进制格式的字符串返回。

以下是一个使用MD5加密的例子:

const originalString = "Hello, world!";
const hashedString = md5(originalString);
​
console.log("Original string:", originalString);
console.log("Hashed string:", hashedString);

运行上述代码,输出将会是:

Original string: Hello, world!
Hashed string: ed076287532e86365e841e92bfc50d8c

AES加密

AES是一种对称密钥加密算法,广泛应用于数据加密和保护。以下是JavaScript实现AES加密的代码:

function aesEncrypt(str, key) {
  let encrypted = CryptoJS.AES.encrypt(str, key);
  return encrypted.toString();
}
​
function aesDecrypt(str, key) {
  let decrypted = CryptoJS.AES.decrypt(str, key);
  return decrypted.toString(CryptoJS.enc.Utf8);
}

这里我们同样使用了CryptoJS库来实现AES加密。我们首先调用CryptoJS.AES.encrypt()函数来加密输入字符串,然后将结果转换为字符串并返回。解密过程也很类似,我们调用CryptoJS.AES.decrypt()函数来解密字符串,然后将结果转换为UTF-8格式的字符串并返回。

以下是一个使用AES加密的例子:

const originalString = "Hello, world!";
const key = "my-secret-key";
​
const encryptedString = aesEncrypt(originalString, key);
const decryptedString = aesDecrypt(encryptedString, key);
​
console.log("Original string:", originalString);
console.log("Encrypted string:", encryptedString);
console.log("Decrypted string:", decryptedString);

运行上述代码,输出将会是:

Original string: Hello, world!
Encrypted string: U2FsdGVkX19Jj+YoIjqJZvT8WxtsA9X+wLjKzFMGk8M=
Decrypted string: Hello, world!

以上是一个常规JavaScript加密大全及案例代码,希望可以对你有所帮助!

jsjiami.com

如果您对文章内容有不同看法,或者疑问,欢迎到评论区留言,或者私信我都可以。

也可以到上方网站,底部有我联系方式详谈

如遇自己源码加密后没备份,可以找我们解决解出恢复源码,任何加密都可以

本文转载于:

https://juejin.cn/post/7221350704471785530

如果对您有所帮助,欢迎您点个关注,我会定时更新技术文档,大家一起讨论学习,一起进步。

 记录-JavaScript常规加密技术

原文链接:https://www.cnblogs.com/smileZAZ/p/17330561.html

本站文章如无特殊说明,均为本站原创,如若转载,请注明出处:记录-JavaScript常规加密技术 - Python技术站

(0)
上一篇 2023年4月19日
下一篇 2023年4月19日

相关文章

  • Express框架req res对象使用详解

    下面是关于“Express框架req res对象使用详解”的完整攻略。 1. HTTP请求(req)对象 Express框架提供了一个request对象(通常缩写为 req),作为每个请求的入口点,它包含了HTTP请求的属性和方法。 1.1 请求路径 req.path属性可用于获取请求的路径,例如: app.get(‘/users/:id’, functio…

    JavaScript 2023年6月11日
    00
  • js Math 对象的方法

    当我们要对数字进行一些复杂的操作或计算时,js语言内置的 Math 对象是不可或缺的一个工具。Math 对象提供了很多有用的方法来处理数字。 常用方法 Math.abs() Math.abs() 方法用于返回给定数字的绝对值,即该数字距离 0 的距离,无论正负。 Math.abs(-5); // 返回 5 Math.abs(5); // 返回 5 Math.…

    JavaScript 2023年5月28日
    00
  • Bootstrap Fileinput文件上传组件用法详解

    Bootstrap Fileinput文件上传组件用法详解 Bootstrap Fileinput是一款基于Bootstrap的文件上传组件,可以方便地进行文件上传并对上传的文件进行一些处理。 安装 下载源码 可以从 Bootstrap Fileinput 的官方 Github 页面下载源码:https://github.com/kartik-v/boots…

    JavaScript 2023年5月28日
    00
  • 常见的JS字符串属性与方法集锦

    让我们来详细讲解一下JS字符串属性与方法的常见用法。 字符串的属性 字符串是一个基本的数据类型,在JavaScript中,字符串属性和方法是相当的丰富。我们来看看一些常见的字符串属性: length 字符串的 length 属性是一个在字符串中含有的字符数,比如: const str = "hello world"; console.lo…

    JavaScript 2023年5月19日
    00
  • JavaScript 中使用 Generator的方法

    JavaScript 中使用 Generator 是一种非常强大的技术,可以将异步代码写得更加简单易懂,但对于初学者来说,掌握 Generator 并不是一件容易的事情。下面是使用 Generator 的详细攻略: 什么是 Generator Generator 是 ES6 中的新特性,它是一种函数,可以暂停并恢复函数执行。在 Generator 函数中,我…

    JavaScript 2023年6月10日
    00
  • javascript之Partial Application学习

    JavaScript之Partial Application学习 在JavaScript中,我们经常需要使用函数来处理数据。在函数式编程中,函数通常被看作是一种“一等公民”,也就是说,函数可以像其他数据类型一样被传递、存储和操作。Partial Application是函数式编程中很重要的概念之一,本篇攻略将全面介绍Partial Application的相…

    JavaScript 2023年5月28日
    00
  • (跨浏览器基础事件/浏览器检测/判断浏览器)经验代码分享

    跨浏览器基础事件 跨浏览器基础事件是指在不同浏览器中实现基础事件的方法。如键盘事件、鼠标事件等。下面是一些实现跨浏览器基础事件的方法: 使用addEventListener方法 addEventListener方法是HTML DOM Event对象的方法,用于将事件与指定元素或对象绑定起来。可以传递三个参数:事件类型、事件发生时需要处理的函数、以及一个布尔值…

    JavaScript 2023年6月11日
    00
  • JS实现HTML页面中动态显示当前时间完整示例

    JS可以通过调用内置的Date对象,来实现在HTML页面中动态显示当前时间,步骤如下: HTML部分 首先需要在HTML页面中准备好用来显示动态时间的元素,可以是<div>、<p>或<span>等,例如: <body> <p id="time"></p> </b…

    JavaScript 2023年5月27日
    00
合作推广
合作推广
分享本页
返回顶部