五种常用的web加密算法

文章目录

  • 五种常用Web加密算法实战及原理详解
    • 1. AES (高级加密标准)
      • 原理详解
      • 应用场景
      • 实战代码(Node.js)
    • 2. RSA (非对称加密)
      • 原理详解
      • 应用场景
      • 实战代码(Node.js)
    • 3. SHA-256 (安全哈希算法)
      • 原理详解
      • 应用场景
      • 实战代码(浏览器环境)
    • 4. HMAC (基于哈希的消息认证码)
      • 原理详解
      • 应用场景
      • 实战代码(Node.js)
    • 5. PBKDF2 (基于密码的密钥派生函数)
      • 原理详解
      • 应用场景
      • 实战代码(Node.js)
    • 加密算法对比表
    • 安全最佳实践
    • 进阶主题

在这里插入图片描述

五种常用Web加密算法实战及原理详解

在现代Web开发中,数据安全至关重要。以下是五种最常用的Web加密算法,包括它们的原理、应用场景和实战代码示例。

1. AES (高级加密标准)

原理详解

AES是一种对称加密算法,使用相同的密钥进行加密和解密。它采用替代-置换网络(SPN)结构,主要步骤包括:

  1. 密钥扩展:从初始密钥派生多轮密钥
  2. 初始轮:AddRoundKey(轮密钥加)
  3. 主轮(重复9-13次):
    • SubBytes(字节替换)
    • ShiftRows(行移位)
    • MixColumns(列混淆)
    • AddRoundKey
  4. 最终轮(省略MixColumns)

AES有三种密钥长度:128位、192位和256位,分别对应10、12和14轮加密。

应用场景

  • HTTPS传输中的数据加密
  • 数据库敏感字段加密
  • 文件加密存储

实战代码(Node.js)

const crypto = require('crypto');// AES-256-CBC加密
function encrypt(text, key, iv) {const cipher = crypto.createCipheriv('aes-256-cbc', Buffer.from(key), iv);let encrypted = cipher.update(text);encrypted = Buffer.concat([encrypted, cipher.final()]);return encrypted.toString('hex');
}// AES-256-CBC解密
function decrypt(encryptedText, key, iv) {const encryptedBuffer = Buffer.from(encryptedText, 'hex');const decipher = crypto.createDecipheriv('aes-256-cbc', Buffer.from(key), iv);let decrypted = decipher.update(encryptedBuffer);decrypted = Buffer.concat([decrypted, decipher.final()]);return decrypted.toString();
}// 使用示例
const key = crypto.randomBytes(32); // 256位密钥
const iv = crypto.randomBytes(16);  // 初始向量
const message = 'Secret Message';const encrypted = encrypt(message, key, iv);
console.log('Encrypted:', encrypted);const decrypted = decrypt(encrypted, key, iv);
console.log('Decrypted:', decrypted);

2. RSA (非对称加密)

在这里插入图片描述

原理详解

RSA基于大整数因数分解的困难性,主要步骤:

  1. 密钥生成
    • 选择两个大素数p和q
    • 计算n = pq,φ(n) = (p-1)(q-1)
    • 选择e使得1 < e < φ(n)且gcd(e, φ(n)) = 1
    • 计算d ≡ e⁻¹ mod φ(n)
    • 公钥=(e, n),私钥=(d, n)
  2. 加密:c ≡ mᵉ mod n
  3. 解密:m ≡ cᵈ mod n

应用场景

  • SSL/TLS握手过程中的密钥交换
  • 数字签名
  • 小数据量加密(如加密对称密钥)

实战代码(Node.js)

const crypto = require('crypto');// 生成RSA密钥对
const { publicKey, privateKey } = crypto.generateKeyPairSync('rsa', {modulusLength: 2048, // 密钥长度publicKeyEncoding: {type: 'spki',format: 'pem'},privateKeyEncoding: {type: 'pkcs8',format: 'pem'}
});// RSA加密
function rsaEncrypt(data, publicKey) {return crypto.publicEncrypt({key: publicKey,padding: crypto.constants.RSA_PKCS1_OAEP_PADDING,oaepHash: 'sha256'}, Buffer.from(data)).toString('base64');
}// RSA解密
function rsaDecrypt(encryptedData, privateKey) {return crypto.privateDecrypt({key: privateKey,padding: crypto.constants.RSA_PKCS1_OAEP_PADDING,oaepHash: 'sha256'}, Buffer.from(encryptedData, 'base64')).toString();
}// 使用示例
const message = 'Confidential Data';const encrypted = rsaEncrypt(message, publicKey);
console.log('RSA Encrypted:', encrypted);const decrypted = rsaDecrypt(encrypted, privateKey);
console.log('RSA Decrypted:', decrypted);

3. SHA-256 (安全哈希算法)

在这里插入图片描述

原理详解

SHA-256是SHA-2家族的一员,产生256位哈希值。其工作流程:

  1. 预处理
    • 填充消息使其长度为512位的倍数
    • 附加原始消息长度
  2. 哈希计算
    • 将消息分成512位块
    • 对每个块应用64轮压缩函数
    • 使用8个初始哈希值和64个预定义常数
    • 每轮包括消息调度、工作变量更新等操作
  3. 输出:最终8个工作变量连接形成256位哈希

应用场景

  • 密码存储
  • 数据完整性验证
  • 区块链和加密货币
  • 数字签名

实战代码(浏览器环境)

// 浏览器中使用Web Crypto API进行SHA-256哈希
async function sha256Hash(message) {// 将字符串编码为Uint8Arrayconst encoder = new TextEncoder();const data = encoder.encode(message);// 计算哈希const hashBuffer = await crypto.subtle.digest('SHA-256', data);// 将ArrayBuffer转换为十六进制字符串const hashArray = Array.from(new Uint8Array(hashBuffer));const hashHex = hashArray.map(b => b.toString(16).padStart(2, '0')).join('');return hashHex;
}// 使用示例
sha256Hash('Hello World').then(hash => console.log('SHA-256 Hash:', hash));

4. HMAC (基于哈希的消息认证码)

在这里插入图片描述

原理详解

HMAC结合加密哈希函数和密钥,提供消息认证。公式为:

HMAC(K, m) = H((K ⊕ opad) || H((K ⊕ ipad) || m))

其中:

  • H是哈希函数(如SHA-256)
  • K是密钥
  • m是消息
  • opad是外部填充(0x5c重复)
  • ipad是内部填充(0x36重复)

应用场景

  • API请求认证
  • JWT签名
  • 消息完整性验证

实战代码(Node.js)

const crypto = require('crypto');// 生成HMAC
function generateHMAC(message, secret) {return crypto.createHmac('sha256', secret).update(message).digest('hex');
}// 验证HMAC
function verifyHMAC(message, secret, hmac) {const expectedHmac = generateHMAC(message, secret);return crypto.timingSafeEqual(Buffer.from(expectedHmac),Buffer.from(hmac));
}// 使用示例
const secretKey = 'mySecretKey123';
const message = 'Important Data';const hmac = generateHMAC(message, secretKey);
console.log('HMAC:', hmac);const isValid = verifyHMAC(message, secretKey, hmac);
console.log('Verification:', isValid ? 'Valid' : 'Invalid');

5. PBKDF2 (基于密码的密钥派生函数)

在这里插入图片描述

原理详解

PBKDF2通过重复哈希增强弱密码的安全性:

  1. 输入密码、盐值、迭代次数和期望密钥长度
  2. 对密码和盐值应用HMAC多次(迭代)
  3. 每次迭代的输出与前一次结果异或
  4. 最终组合所有块生成派生密钥

应用场景

  • 用户密码存储
  • 从密码生成加密密钥

实战代码(Node.js)

const crypto = require('crypto');// 使用PBKDF2派生密钥
function deriveKey(password, salt, iterations, keyLength, digest) {return crypto.pbkdf2Sync(password,salt,iterations,keyLength,digest).toString('hex');
}// 使用示例
const password = 'userPassword123';
const salt = crypto.randomBytes(16).toString('hex'); // 生成随机盐
const iterations = 10000; // 迭代次数
const keyLength = 32; // 密钥长度(字节)
const digest = 'sha256'; // 哈希算法const derivedKey = deriveKey(password, salt, iterations, keyLength, digest);
console.log('Derived Key:', derivedKey);
console.log('Salt:', salt);// 验证密码示例
function verifyPassword(password, storedHash, storedSalt, iterations, keyLength, digest) {const newHash = deriveKey(password, storedSalt, iterations, keyLength, digest);return newHash === storedHash;
}const isMatch = verifyPassword('userPassword123',derivedKey,salt,iterations,keyLength,digest
);
console.log('Password Match:', isMatch);

加密算法对比表

算法类型密钥长度安全性性能适用场景
AES对称加密128/192/256位大数据量加密
RSA非对称加密2048位+密钥交换、数字签名
SHA-256哈希算法256位输出数据完整性验证
HMAC消息认证码可变中等消息认证
PBKDF2密钥派生可变可调密码存储

安全最佳实践

  1. 密钥管理

    • 永远不要硬编码密钥
    • 使用密钥管理系统(如AWS KMS、Hashicorp Vault)
    • 定期轮换密钥
  2. 算法选择

    • 对称加密首选AES-256
    • 非对称加密使用RSA 2048位或ECC 256位+
    • 哈希函数使用SHA-256或SHA-3
  3. 密码存储

    • 永远不要明文存储密码
    • 使用PBKDF2、bcrypt或Argon2
    • 每个用户使用唯一盐值
  4. 传输安全

    • 始终使用HTTPS
    • 敏感数据在客户端也应加密
  5. 错误处理

    • 加密失败时不要暴露详细信息
    • 使用恒定时间比较防止时序攻击

进阶主题

  1. 椭圆曲线加密(ECC):比RSA更高效的非对称加密
  2. bcrypt/Argon2:更现代的密码哈希算法
  3. 量子安全加密:抗量子计算的算法(如格密码)
  4. 同态加密:在加密数据上直接计算
  5. 零知识证明:验证信息而不泄露信息本身

通过掌握这五种核心加密算法及其实现,您已经具备了构建安全Web应用的基础能力。在实际项目中,应根据具体需求选择合适的算法组合,并遵循安全最佳实践来保护用户数据。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/diannao/77512.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

深入解析 C++ 设计模式:原理、实现与应用

一、引言 在 C 编程的广袤领域中&#xff0c;设计模式犹如闪耀的灯塔&#xff0c;为开发者指引着构建高效、可维护软件系统的方向。设计模式并非神秘莫测的代码魔法&#xff0c;实际上&#xff0c;我们在日常编程中或许早已与之打过交道。简单来说&#xff0c;设计模式常常借助…

Python刷题笔记

Python刷题笔记 1、输出格式化 第一种格式化的输出&#xff1a; name "jack" age 17 salary 20031.8752 print("你的名字是&#xff1a;%s,今年 %d 岁,工资 %7.2f" % (name,age,salary) ) --------------------------------------- 你的名字是&#…

【Kubernetes】Kubernetes 如何进行日志管理?Fluentd / Loki / ELK 适用于什么场景?

由于 Kubernetes 运行在容器化的环境中&#xff0c;应用程序和系统日志通常分布在多个容器和节点上&#xff0c;传统的日志管理方法&#xff08;例如直接访问每个节点的日志文件&#xff09;在 Kubernetes 中不适用。 因此&#xff0c;Kubernetes 引入了集中式日志管理方案&am…

Ansible(8)——循环与条件任务

目录 一、循环迭代任务&#xff1a; 1、简单循环&#xff1a; 2、循环字典列表&#xff1a; 3、Ansible 2.5 之前的循环关键字&#xff1a; 4、在循环中使用 register 变量&#xff1a; 二、条件任务&#xff1a; 1、使用条件句的常见场景&#xff1a; 2、条件任务语法…

adb|scrcpy的安装和配置方法|手机投屏电脑|手机声音投电脑|adb连接模拟器或手机

adb|scrcpy的安装和配置方法手机投屏电脑|手机声音投电脑|adb连接模拟器或手机或电视 引言 在数字设备交织的现代生活中&#xff0c;adb&#xff08;Android Debug Bridge&#xff09;与 scrcpy 宛如隐匿的强大工具&#xff0c;极大地拓展了我们操控手机、模拟器乃至智能电视等…

vue3项目集成electron

一、环境准备 1. 确保已安装 Node.js (建议版本 16.x 或更高) 2. 创建或进入现有 Vue 项目目录 cd your-vue-project 二、添加 Electron 支持 在项目根目录执行: vue add electron-builder 执行后会在 `src` 目录下生成 `background.js` 主进程文件。 三、主进程配置 (ba…

循环神经网络 - 参数学习之随时间反向传播算法

本文中&#xff0c;我们以同步的序列到序列模式为例来介绍循环神经网络的参数学习。 循环神经网络中存在一个递归调用的函数 &#x1d453;(⋅)&#xff0c;因此其计算参数梯度的方式和前馈神经网络不太相同。在循环神经网络中主要有两种计算梯度的方式&#xff1a;随时间反向…

体验OceanBase的 并行导入功能

在数据库的日常使用中&#xff0c;会经常遇到以下场景&#xff1a; ‌数据复制‌&#xff1a;将一个或多个表中的数据复制到目标表中&#xff0c;可能是复制全部数据&#xff0c;也可能仅复制部分数据。数据合并&#xff1a;将数据从一个表转移到另一个表&#xff0c;或者将多…

Kafka和RocketMQ相比有什么区别?那个更好用?

Kafka和RocketMQ相比有什么区别?那个更好用? Kafka 和 RocketMQ 都是广泛使用的消息队列系统&#xff0c;它们有很多相似之处&#xff0c;但也有一些关键的区别。具体选择哪个更好用&#xff0c;要根据你的应用场景和需求来决定。以下是它们之间的主要区别&#xff1a; 1. …

UniApp 实现兼容 H5 和小程序的拖拽排序组件

如何使用 UniApp 实现一个兼容 H5 和小程序的 九宫格拖拽排序组件&#xff0c;实现思路和关键步骤。 一、实现目标 支持拖动菜单项改变顺序拖拽过程实时预览移动位置拖拽松开后自动吸附回网格兼容 H5 和小程序平台 二、功能结构拆解以及完整代码 完整代码&#xff1a; <…

[raspberrypi 0w and respeaker 2mic]实时音频波形

0. 环境 ubuntu22主机&#xff0c; 192.168.8.162&#xff0c; raspberry 0w&#xff0c; 192.168.8.220 路由器 1. 树莓派 # rpi - send.py # 或者命令行&#xff1a;arecord -D plughw:1,0 -t wav -f cd -r 16000 -c 2 | nc 192.168.8.162 12345import socket imp…

公司内部建立apt源

有一篇建立pypi源的在这里需要的可以查看&#xff1a;公司内部建立pypi源-CSDN博客 背景&#xff0c;公司内部有很多工具仅供内部使用&#xff0c;如果用apt的方式就比较方便&#xff0c;只需要修改sources.list将源添加进去就可以了。我们接下来的操作就是为了实现这个需求。…

UE5中如何修复后处理动画蓝图带来的自然状态下的metablriger身体绑定形变(如耸肩)问题

【[metablriger] UE5中如何修复后处理动画蓝图带来的自然状态下的metablriger身体绑定形变(如耸肩)问题】 UE5中如何修复后处理动画蓝图带来的自然状态下的metablriger身体绑定形变(如耸肩)问题

AWS Bedrock生成视频详解:AI视频创作新时代已来临

💡 TL;DR: AWS Bedrock现已支持AI视频生成功能,让企业无需深厚AI专业知识即可创建高质量视频内容。本文详解Bedrock视频生成能力的工作原理、应用场景和实操指南,助你快速掌握这一革命性技术。 🎬 AWS Bedrock视频生成:改变内容创作的游戏规则 还记得几年前,制作一个专…

1.2 测试设计阶段:打造高质量的测试用例

测试设计阶段&#xff1a;打造高质量的测试用例 摘要 本文详细介绍了软件测试流程中的测试设计阶段&#xff0c;包括测试用例设计、测试数据准备、测试环境搭建和测试方案设计等内容。通过本文&#xff0c;读者可以系统性地了解测试设计的方法和技巧&#xff0c;掌握如何高效…

jQueryHTML与插件

1.jQuery 事件机制 1.1 注册事件 bind()、on()方法向被选元素添加一个或多个事件处理程序&#xff0c;以及当事件发生时运行的函数 $("p").on({"click": function () {alert("点击了")},"mouseenter": function () {…

MySQL 触发器与存储过程:数据库的自动化工厂

在数据世界的工业区&#xff0c;有一座运转高效的自动化工厂&#xff0c;那里的机器人日夜不停地处理数据…这就是 MySQL 的触发器与存储过程系统&#xff0c;它让数据库从"手工作坊"变成了"现代化工厂"… 什么是 MySQL 触发器与存储过程&#xff1f;&…

PostgreSQL-中文字段排序-修改字段的排序规则

最新版本更新 https://code.jiangjiesheng.cn/article/365?fromcsdn 推荐 《高并发 & 微服务 & 性能调优实战案例100讲 源码下载》 -- 修改字段的排序规则 ALTER TABLE "public"."your_table_name" ALTER COLUMN "name" TYPE varcha…

GitHub优秀项目:数据湖的管理系统LakeFS

lakeFS 是一个开源工具&#xff0c;它将用户的对象存储转换为类似Git的存储库。使用户可以像管理代码一样管理数据湖。借助 lakeFS&#xff0c;可以构建可重复、原子化和版本化的数据湖操作--从复杂的ETL作业到数据科学和分析。 Stars 数11090Forks 数3157 主要特点 强大的数据…

页面编辑器CodeMirror初始化不显示行号或文本内容

延迟刷新 本来想延迟100毫秒的&#xff0c;但是会出现样式向左偏移的情况&#xff0c;于是试了试500毫秒&#xff0c;发现就没有问题了&#xff0c;可能是样式什么是需要一个加载过程吧。 useEffect(() > {editorRef.current?.setValue(value || );setTimeout(() > {edi…