js中怎样对“abc”进行MD5、sha256哈希计算?

2024-09-06 14:44

本文主要是介绍js中怎样对“abc”进行MD5、sha256哈希计算?,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

在 JavaScript 中,可以使用 CryptoJS 库来进行 MD5 哈希计算。首先,你需要在 HTML 文件中导入 CryptoJS 库,例如:

<script src="https://cdnjs.cloudflare.com/ajax/libs/crypto-js/3.1.9-1/crypto-js.min.js"></script>

然后,在 JavaScript 文件中,可以使用以下代码对字符串 "abc" 进行 MD5 哈希计算:

var hash = CryptoJS.MD5("abc");
var hashString = hash.toString();
console.log(hashString);

运行以上代码后,将在控制台输出 MD5 哈希值。

请注意,CryptoJS 库提供了多种哈希算法,包括 MD5、SHA1、SHA256 等。你可以根据需要选择适合的算法进行哈希计算。

在JavaScript中,可以使用CryptoJS库来计算SHA256哈希值。首先,需要将字符串转换为字节数组,然后使用CryptoJS.SHA256()方法计算哈希值。以下是一个示例代码:

// 导入CryptoJS库
const CryptoJS = require('crypto-js');// 定义要计算哈希值的字符串
const str = "abc";// 将字符串转换为字节数组
const wordArray = CryptoJS.enc.Utf8.parse(str);// 计算SHA256哈希值
const hash = CryptoJS.SHA256(wordArray);// 将哈希值转换为十六进制字符串
const hashStr = hash.toString(CryptoJS.enc.Hex);// 打印SHA256哈希值
console.log(hashStr);

上述代码使用了Node.js的require()函数来导入CryptoJS库。如果在浏览器环境中使用,可以使用script标签导入CryptoJS库。

请注意,以上代码在Node.js环境下运行。如果在浏览器环境中使用,需要导入CryptoJS库的适当版本,并且可能需要进行一些调整。如下:

浏览器中,可以使用crypto.subtle.digest()方法来对字符串进行SHA256哈希计算。

下面是一个简单的示例代码:

async function sha256(input) {const encoder = new TextEncoder();const data = encoder.encode(input);const hashBuffer = await crypto.subtle.digest('SHA-256', data);const hashArray = Array.from(new Uint8Array(hashBuffer));const hashHex = hashArray.map(byte => byte.toString(16).padStart(2, '0')).join('');return hashHex;
}const str = 'abc';
sha256(str).then(hash => console.log(hash));

这段代码定义了一个sha256函数,它接收一个字符串作为输入,并返回计算出的SHA256哈希值。在函数内部,我们首先使用TextEncoder将字符串编码为字节数组,然后使用crypto.subtle.digest()方法对字节数组进行SHA256哈希计算。最后,将计算出的哈希值转换为十六进制字符串并返回。

通过调用sha256()函数,并将要计算哈希的字符串作为参数传入,就可以得到计算出的SHA256哈希值。

看晕了么?一个问题下面连接了太多的问题。

这篇关于js中怎样对“abc”进行MD5、sha256哈希计算?的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1142302

相关文章

JS常用组件收集

收集了一些平时遇到的前端比较优秀的组件,方便以后开发的时候查找!!! 函数工具: Lodash 页面固定: stickUp、jQuery.Pin 轮播: unslider、swiper 开关: switch 复选框: icheck 气泡: grumble 隐藏元素: Headroom

哈希leetcode-1

目录 1前言 2.例题  2.1两数之和 2.2判断是否互为字符重排 2.3存在重复元素1 2.4存在重复元素2 2.5字母异位词分组 1前言 哈希表主要是适合于快速查找某个元素(O(1)) 当我们要频繁的查找某个元素,第一哈希表O(1),第二,二分O(log n) 一般可以分为语言自带的容器哈希和用数组模拟的简易哈希。 最简单的比如数组模拟字符存储,只要开26个c

【Prometheus】PromQL向量匹配实现不同标签的向量数据进行运算

✨✨ 欢迎大家来到景天科技苑✨✨ 🎈🎈 养成好习惯,先赞后看哦~🎈🎈 🏆 作者简介:景天科技苑 🏆《头衔》:大厂架构师,华为云开发者社区专家博主,阿里云开发者社区专家博主,CSDN全栈领域优质创作者,掘金优秀博主,51CTO博客专家等。 🏆《博客》:Python全栈,前后端开发,小程序开发,人工智能,js逆向,App逆向,网络系统安全,数据分析,Django,fastapi

在JS中的设计模式的单例模式、策略模式、代理模式、原型模式浅讲

1. 单例模式(Singleton Pattern) 确保一个类只有一个实例,并提供一个全局访问点。 示例代码: class Singleton {constructor() {if (Singleton.instance) {return Singleton.instance;}Singleton.instance = this;this.data = [];}addData(value)

usaco 1.3 Prime Cryptarithm(简单哈希表暴搜剪枝)

思路: 1. 用一个 hash[ ] 数组存放输入的数字,令 hash[ tmp ]=1 。 2. 一个自定义函数 check( ) ,检查各位是否为输入的数字。 3. 暴搜。第一行数从 100到999,第二行数从 10到99。 4. 剪枝。 代码: /*ID: who jayLANG: C++TASK: crypt1*/#include<stdio.h>bool h

业务中14个需要进行A/B测试的时刻[信息图]

在本指南中,我们将全面了解有关 A/B测试 的所有内容。 我们将介绍不同类型的A/B测试,如何有效地规划和启动测试,如何评估测试是否成功,您应该关注哪些指标,多年来我们发现的常见错误等等。 什么是A/B测试? A/B测试(有时称为“分割测试”)是一种实验类型,其中您创建两种或多种内容变体——如登录页面、电子邮件或广告——并将它们显示给不同的受众群体,以查看哪一种效果最好。 本质上,A/B测

poj 1113 凸包+简单几何计算

题意: 给N个平面上的点,现在要在离点外L米处建城墙,使得城墙把所有点都包含进去且城墙的长度最短。 解析: 韬哥出的某次训练赛上A出的第一道计算几何,算是大水题吧。 用convexhull算法把凸包求出来,然后加加减减就A了。 计算见下图: 好久没玩画图了啊好开心。 代码: #include <iostream>#include <cstdio>#inclu

uva 1342 欧拉定理(计算几何模板)

题意: 给几个点,把这几个点用直线连起来,求这些直线把平面分成了几个。 解析: 欧拉定理: 顶点数 + 面数 - 边数= 2。 代码: #include <iostream>#include <cstdio>#include <cstdlib>#include <algorithm>#include <cstring>#include <cmath>#inc

uva 11178 计算集合模板题

题意: 求三角形行三个角三等分点射线交出的内三角形坐标。 代码: #include <iostream>#include <cstdio>#include <cstdlib>#include <algorithm>#include <cstring>#include <cmath>#include <stack>#include <vector>#include <

XTU 1237 计算几何

题面: Magic Triangle Problem Description: Huangriq is a respectful acmer in ACM team of XTU because he brought the best place in regional contest in history of XTU. Huangriq works in a big compa