当前位置: 首页 > article >正文

node.js内置模块之---crypto 模块

crypto 模块的作用在 Node.js 中crypto模块提供了多种加密功能包括哈希、对称加密、非对称加密和数字签名等。通过crypto模块可以进行各种加密和解密操作保护敏感数据的安全性。crypto 模块1. 哈希算法Hashing哈希函数如 SHA、MD5 等用于将输入数据映射为一个固定长度的字符串哈希值。它是单向的不可逆的通常用于数据完整性验证。createHash(algorithm)创建一个哈希对象algorithm指定使用的哈希算法例如sha256,md5。update(data)向哈希对象添加数据可以调用多次。digest(encoding)返回哈希值encoding可以是hex、base64或binary。示例生成 SHA-256 哈希值const hash crypto.createHash(sha256); hash.update(Hello, world!); const result hash.digest(hex); console.log(result); // 输出 SHA-256 哈希值2、加密与解密Encryption and Decryption对称加密对称加密使用相同的密钥进行加密和解密。crypto模块支持多种对称加密算法如 AESAES-128、AES-256等。createCipheriv(algorithm, key, iv)创建加密对象algorithm是加密算法key是密钥iv是初始化向量IV。update(data, inputEncoding, outputEncoding)将明文数据输入并指定编码返回加密数据。final(outputEncoding)返回最后的加密数据。示例使用 AES-256-CBC 加密和解密const algorithm aes-256-cbc; const key crypto.randomBytes(32); // 32 字节的密钥 const iv crypto.randomBytes(16); // 16 字节的初始化向量 // 加密 const cipher crypto.createCipheriv(algorithm, key, iv); let encrypted cipher.update(Hello, world!, utf8, hex); encrypted cipher.final(hex); console.log(Encrypted:, encrypted); // 解密 const decipher crypto.createDecipheriv(algorithm, key, iv); let decrypted decipher.update(encrypted, hex, utf8); decrypted decipher.final(utf8); console.log(Decrypted:, decrypted);非对称加密非对称加密使用一对密钥——公钥和私钥。公钥用于加密私钥用于解密。generateKeyPairSync(type, options)同步生成公钥和私钥对type指定密钥类型如rsaoptions指定密钥的参数。publicEncrypt(publicKey, data)使用公钥对数据进行加密。privateDecrypt(privateKey, data)使用私钥对数据进行解密。示例使用 RSA 非对称加密const { publicKey, privateKey } crypto.generateKeyPairSync(rsa, { modulusLength: 2048, // 公钥的位数 }); // 使用公钥加密 const encrypted crypto.publicEncrypt(publicKey, Buffer.from(Hello, world!)); console.log(Encrypted:, encrypted.toString(hex)); // 使用私钥解密 const decrypted crypto.privateDecrypt(privateKey, encrypted); console.log(Decrypted:, decrypted.toString());3. HMACHash-based Message Authentication CodeHMAC 是一种基于哈希的消息认证码用于验证消息的完整性和真实性。它结合了哈希函数和密钥能够防止中间人攻击。createHmac(algorithm, key)创建 HMAC 对象algorithm指定哈希算法如sha256key是密钥。update(data)向 HMAC 对象输入数据。digest(encoding)返回 HMAC 的结果通常是hex或base64编码。示例生成 HMACconst secret my-secret-key; const hmac crypto.createHmac(sha256, secret); hmac.update(Hello, world!); const result hmac.digest(hex); console.log(HMAC:, result);4. 随机数生成Random Number Generationcrypto提供了生成安全随机数的功能用于生成随机密码、令牌等。randomBytes(size)生成指定字节数的随机数据。示例生成随机字节const randomBytes crypto.randomBytes(16); // 生成16个随机字节 console.log(randomBytes.toString(hex)); // 输出十六进制字符串5. 数字签名Digital Signature数字签名用于验证数据的完整性和身份认证通常用于公钥基础设施PKI中。它使用私钥对数据签名使用公钥验证签名。createSign(algorithm)创建一个签名对象algorithm指定哈希算法。createVerify(algorithm)创建一个验证签名对象algorithm指定哈希算法。sign(privateKey, encoding)使用私钥对数据进行签名。verify(publicKey, signature, encoding)使用公钥验证签名。示例生成签名const { privateKey, publicKey } crypto.generateKeyPairSync(rsa, { modulusLength: 2048, }); // 生成签名 const sign crypto.createSign(SHA256); sign.update(Hello, world!); const signature sign.sign(privateKey, hex); console.log(Signature:, signature); // 验证签名 const verify crypto.createVerify(SHA256); verify.update(Hello, world!); const isVerified verify.verify(publicKey, signature, hex); console.log(Verified:, isVerified); // true 或 false6. 密钥对生成Key Pair Generation非对称加密中公钥和私钥的生成可以通过crypto.generateKeyPairSync方法。generateKeyPairSync(type, options)生成公钥和私钥对type指定加密算法类型如rsaoptions包含密钥的相关参数。export(options)将密钥导出为 PEM 格式。示例生成 RSA 密钥对const { privateKey, publicKey } crypto.generateKeyPairSync(rsa, { modulusLength: 2048, }); console.log(Private Key:, privateKey.export({ type: pkcs1, format: pem })); console.log(Public Key:, publicKey.export({ type: pkcs1, format: pem }));

相关文章:

node.js内置模块之---crypto 模块

crypto 模块的作用 在 Node.js 中,crypto 模块提供了多种加密功能,包括哈希、对称加密、非对称加密和数字签名等。通过 crypto 模块,可以进行各种加密和解密操作,保护敏感数据的安全性。 crypto 模块 1. 哈希算法(Hash…...

【IEEE出版、EI稳定检索】2026年第三届先进机器人,自动化工程与机器学习国际会议(ARAEML 2026)

当下,智能制造与人工智能的融合创新正驱动全球产业变革,先进机器人、自动化工程与机器学习技术也迎来从技术突破到场景落地的关键跨越。这一发展浪潮不仅重构了智能装备、工业智造、智能感知等领域的技术应用体系,更在机器人自主导航、算法工…...

伏羲天气预报GPU算力适配:A10/A100显存占用与batch size最优配置表

伏羲天气预报GPU算力适配:A10/A100显存占用与batch size最优配置表 1. 引言:为什么需要GPU配置表? 如果你正在使用复旦大学的伏羲(FuXi)中期气象大模型,可能已经发现,虽然CPU模式能跑&#xf…...

vue for cesium-初学记录-修改工具栏中鼠标放置文字提示

原本以为在 <vc-measurementsareaActionOpts"{tip/tooltip/title等属性可修改鼠标放置时文字提示}"但是不起作用&#xff0c;需要在<vc-measurementsareaActionOpts"{tip/tooltip/title等属性可修改鼠标放置时文字提示}"ready"onMeasurementsRe…...

如何让技术图表绘制效率提升10倍?智能绘图工具赋能开发者与架构师

如何让技术图表绘制效率提升10倍&#xff1f;智能绘图工具赋能开发者与架构师 【免费下载链接】next-ai-draw-io 项目地址: https://gitcode.com/GitHub_Trending/ne/next-ai-draw-io 重新定义图表创作&#xff1a;核心价值解析 传统图表绘制流程中&#xff0c;开发者…...

解决androidsutdio打开多个文件tab自动替换或者关闭问题

参考如下图设置即可&#xff0c;大概率是Opening Policy打上勾的问题...

Qwen3-TTS-Tokenizer-12Hz实战分享:如何将音频高效压缩为离散tokens

Qwen3-TTS-Tokenizer-12Hz实战分享&#xff1a;如何将音频高效压缩为离散tokens 1. 音频压缩新范式&#xff1a;为什么需要离散tokens 在语音处理和传输领域&#xff0c;我们长期面临一个核心矛盾&#xff1a;既要保证音频质量&#xff0c;又要控制数据量。传统音频编码技术&…...

计算机毕业设计springboot学校实验设备管理系统 基于SpringBoot的校园实验仪器全生命周期管理系统 基于SpringBoot的智慧实验室设备运维服务平台

计算机毕业设计springboot学校实验设备管理系统iy4sf356 &#xff08;配套有源码 程序 mysql数据库 论文&#xff09; 本套源码可以在文本联xi,先看具体系统功能演示视频领取&#xff0c;可分享源码参考。随着高等教育事业的蓬勃发展&#xff0c;高校实验室作为培养学生实践创新…...

PHP代码调试(vscode+xdebug+phpstudy)

目录 配置php环境变量 安装xbug 开启xdebug组件 配置php.ini 修改vscode设置? 创建launch.json文件 配置php环境变量 第一步是配置php的环境变量&#xff0c;csdn里有很多文章可以直接搜索即可了解怎么配置&#xff0c;大概就是将phpstudy里的php文件位置复制到环境变量…...

STM32F103C8T6新手避坑指南:从零搭建工程到点亮LED(Keil5完整流程)

STM32F103C8T6新手避坑指南&#xff1a;从零搭建工程到点亮LED&#xff08;Keil5完整流程&#xff09; 第一次接触STM32开发板时&#xff0c;那块蓝色的小板子看起来人畜无害&#xff0c;直到我打开Keil5准备创建第一个工程——连续三个晚上被各种报错折磨得差点放弃嵌入式开发…...

中国30米防风固沙栅格数据(2000/2010/2020)|高精度生态系统服务产品|RWEQ模型|GeoTIFF格式

&#x1f50d; 数据简介 本数据为 中国30米分辨率防风固沙能力栅格数据集&#xff0c;源自北京师范大学赵文武教授团队发布的 《中国高空间分辨率生态系统服务数据集》&#xff08;2000–2020&#xff09;&#xff0c;于2025年2月26日正式上线科学数据银行&#xff08;Science…...

[STM32WBA] 【NUCLEO-WBA65RI 测评】+功耗测试

作为一款蓝牙产品&#xff0c;功耗还是很重要的&#xff0c;需要看你待机能力。在学习蓝牙方面知识之前&#xff0c;再来测试下低功耗 一、硬件连接 查资料得知&#xff0c;需要将JP1断开&#xff0c;并将电流表两端分别接在JP1上。SB1默认是连接的&#xff0c;不需要再连接。二…...

汽车供应链品牌升级框架:用决策链表达替代参数堆叠

汽车供应链企业品牌升级如果只停留在视觉改版&#xff0c;往往很难真正改变客户判断。对B2B项目来说&#xff0c;更有效的做法是把它当成一个“判断系统重构”任务&#xff1a;先定义、再拆问题、再搭骨架、再做场景落地。一、定义&#xff1a;这类升级到底在升级什么 汽车供应…...

12bit高分辨率示波器实战:用RIGOL DHO914S伯德图功能优化电源设计(含操作视频)

12bit高分辨率示波器实战&#xff1a;用RIGOL DHO914S伯德图功能优化电源设计 在电源设计领域&#xff0c;环路稳定性测试是验证系统可靠性的关键环节。传统方法需要组合信号发生器、示波器和分析软件&#xff0c;操作复杂且设备成本高昂。RIGOL DHO914S示波器集成的伯德图功能…...

LangChain Frontend 概述(官方文档总结)

1. 文档核心&#xff1a;LangChain Frontend 是什么&#xff1f;是 LangChain 自带的轻量级 Web 界面作用&#xff1a;不用自己写前端页面&#xff0c;直接给 LLM / Agent / Chain 提供一个可交互的网页定位&#xff1a;快速演示、调试、内部使用&#xff0c;不是生产级前端框架…...

Endnote文献管理实战:如何高效整理Web of Science的4万+文献?

Endnote文献管理实战&#xff1a;如何高效整理Web of Science的4万文献&#xff1f; 当你面对Web of Science导出的43297篇深度学习文献时&#xff0c;是否感到无从下手&#xff1f;作为科研工作者&#xff0c;我们常常陷入这样的困境&#xff1a;海量文献像潮水般涌来&#xf…...

初探 MindSpore(四):把最小训练单元放进数据迭代

初探 MindSpore&#xff08;四&#xff09;&#xff1a;把最小训练单元放进数据迭代 第三篇已经把 MindSpore 的最小训练闭环搭出来了&#xff1a; NetWithLossCellOptimizerTrainOneStepCell 但这还只是“一步训练”。真正进入训练过程&#xff0c;还需要回答两个问题&#xf…...

Phi-3-Mini-128K多轮对话效果深度评测:上下文保持与逻辑一致性

Phi-3-Mini-128K多轮对话效果深度评测&#xff1a;上下文保持与逻辑一致性 最近在体验各种开源大模型时&#xff0c;我一直在想一个问题&#xff1a;一个模型在单轮问答里表现优秀&#xff0c;是不是就意味着它真的“聪明”&#xff1f;答案可能没那么简单。真正的智能对话&am…...

Spring Cloud Java后端面试题精选 - Day 9

Spring Cloud Java后端面试题精选 - Day 9 &#x1f4da; 前言 Spring Cloud作为微服务架构全家桶&#xff0c;在现代Java后端开发中扮演着至关重要的角色。掌握Spring Cloud的相关知识是Java后端工程师面试中的常见考点&#xff0c;也是实际项目开发中的必备技能。 &#x1f5…...

GPT-SoVITS实战:仅需5秒音频,手把手教你克隆专属语音助手

GPT-SoVITS实战&#xff1a;仅需5秒音频&#xff0c;手把手教你克隆专属语音助手 1. 引言&#xff1a;声音克隆技术的新突破 你是否想过拥有一个能完美模仿自己声音的AI助手&#xff1f;或者为你的视频创作打造独特的角色配音&#xff1f;GPT-SoVITS让这一切变得触手可及。这…...

初探 MindSpore(三):把最小网络接上训练

初探 MindSpore&#xff08;三&#xff09;&#xff1a;把最小网络接上训练 前两篇只处理了网络定义本身&#xff1a; nn.Module -> nn.Cellforward() -> construct() 但只会写前向网络还不够。对 PyTorch 用户来说&#xff0c;下一步真正需要搞清楚的是&#xff1a;Mind…...

快速上手Qwen2.5-7B微调:单卡10分钟,打造专属对话机器人

快速上手Qwen2.5-7B微调&#xff1a;单卡10分钟&#xff0c;打造专属对话机器人 1. 为什么你需要尝试Qwen2.5-7B微调 1.1 大模型微调的价值 想象一下&#xff0c;你有一个非常聪明的助手&#xff0c;但它总是以标准化的方式回答所有问题。现在&#xff0c;你想让它记住你的个…...

STM32版FX2N源码与原理图解析:C语言编译的PLC通信程序移植与应用指南

STM32版FX2N源码&原理图&PCB板(可直接移植) FX2N源码V3.8版的使用基本说明&#xff1a; 编译语言&#xff1a;C语言 FX2N源码V3.8版是根据三菱FX2N的PLC通信协议、通信命令以及基于STM32F103系列单片机上编写运行的程序&#xff0c;可以直接利用三菱编程软件编写梯形图…...

简历制作效率革命:Reactive-Resume全场景应用指南

简历制作效率革命&#xff1a;Reactive-Resume全场景应用指南 【免费下载链接】Reactive-Resume AmruthPillai/Reactive-Resume: 是一个基于 React 和 Firebase 的简历生成工具。适合对 Web 开发和简历制作有兴趣的人&#xff0c;特别是想快速生成个性化简历的人。特点是提供了…...

Windows系统高效预览WebP图片的插件解决方案

1. 为什么Windows系统需要WebP预览插件&#xff1f; 如果你经常从网上下载图片素材&#xff0c;或者和设计师同事打交道&#xff0c;最近两年肯定会发现一种后缀名为.webp的图片越来越多。这种由Google推出的图像格式&#xff0c;用手机拍张照片存成WebP格式&#xff0c;文件大…...

MedGemma 1.5新手入门:三分钟搞定本地医疗AI问答系统

MedGemma 1.5新手入门&#xff1a;三分钟搞定本地医疗AI问答系统 1. 为什么选择本地医疗AI助手 在医疗健康领域&#xff0c;隐私保护和专业可靠性是两个最核心的需求。传统在线医疗AI存在三个明显痛点&#xff1a;健康数据需要上传云端、回答过程像黑盒子无法验证、网络依赖性…...

电力系统新手必看:5分钟搞定IEEE5节点Simulink潮流仿真(附MATLAB代码)

电力系统仿真实战&#xff1a;5分钟掌握IEEE5节点Simulink潮流计算核心技巧 从零开始的电力系统仿真之旅 第一次打开Simulink面对空白的建模画布时&#xff0c;那种无从下手的感觉我至今记忆犹新。作为电力系统分析的基础&#xff0c;潮流计算就像电力工程师的"ABC"&…...

Keil5 MDK在Cortex M系列关于分散加载文件说明指导

类别内容摘要本文结合 SRAM 示例工程&#xff0c;说明如何在Cortex M&#xff08; LCM32F067 &#xff09;工程中使用 Keil 分散加载文件&#xff0c;将部分函数固定到指定 Flash 地址运行&#xff0c;并将部分函数搬运到指定 RAM 地址运行。源代码路径链接: https://pan.baidu…...

ESP32音频开发指南:如何用ESP-ADF的I2S Stream实现高质量音频输出

ESP32音频开发实战&#xff1a;基于I2S Stream的高保真音频输出全解析 在物联网和智能硬件快速发展的今天&#xff0c;音频处理能力已成为嵌入式设备的重要功能之一。ESP32作为一款高性价比的Wi-Fi/蓝牙双模芯片&#xff0c;凭借其强大的处理能力和丰富的外设接口&#xff0c;在…...

火山方舟 Coding Plan 服务变更公告

亲爱的火山方舟 Coding Plan 用户朋友们&#xff1a;大家好&#xff01;首先由衷感谢大家对火山方舟 Coding Plan 的喜爱与支持&#xff01;自产品上线以来&#xff0c;我们收到了远超预期的用户热情&#xff0c;无数订阅者通过 Coding Plan 享受到了高效、便捷的 AI 提效服务&…...