新闻中心
J*aScript加密算法_Web Cryptography API
Web Cryptography API 提供标准化加密功能,支持哈希、对称与非对称加密等操作,通过 crypto.subtle 实现密钥管理、数据加密解密及签名验证,需在 HTTPS 下运行且密钥安全受保护。

Web Cryptography API 是现代浏览器提供的一套底层加密功能,允许开发者在客户端安全地执行常见的加密操作,比如生成密钥、加密解密数据、签名与验证、哈希计算等。它不依赖第三方库,直接通过 J*aScript 调用系统级加密模块,提升了安全性与性能。
支持的加密操作
Web Cryptography API 提供了 crypto.subtle 接口(称为 SubtleCrypto),支持以下核心功能:
- 生成和导入/导出加密密钥(如 AES、RSA、ECDSA)
- 对称加密与解密(如 AES-GCM、AES-CBC)
- 非对称加密与解密(如 RSA-OAEP)
- 数字签名与验证(如 ECDSA、RSA-PSS)
- 数据摘要(哈希)计算(如 SHA-256、SHA-512)
- 密钥派生(如 PBKDF2、HKDF)
基本使用示例
以下是几个常见场景的代码示例,展示如何使用 Web Cryptography API 实现加密功能。
1. 计算 SHA-256 哈希将字符串转换为 ArrayBuffer,然后计算其哈希值:
async function hashData(data) {
const encoder = new TextEncoder();
const dataBuffer = encoder.encode(data);
const hashBuffer = await crypto.subtle.digest('SHA-256', dataBuffer);
return Array.from(new Uint8Array(hashBuffer))
.map(b => b.toString(16).padStart(2, '0'))
.join('');
}
// 使用
hashData('hello world').then(console.log); // 输出: "2ef7bde608ce5404e97d5f042f95f89f1c232871..."
2. 使用 AES-GCM 加密与解密
对称加密适合加密大量数据,密钥需保密:
语鲸
AI智能阅读辅助工具
314
查看详情
async function encryptAES(data, key) {
const encoder = new TextEncoder();
const encodedData = encoder.encode(data);
const iv = crypto.getRandomValues(new Uint8Array(12)); // 初始化向量
const encrypted = await crypto.subtle.encrypt(
{ name: 'AES-GCM', iv },
key,
encodedData
);
return { encrypted, iv };
}
async function decryptAES(encryptedData, key, iv) {
const decrypted = await crypto.subtle.decrypt(
{ name: 'AES-GCM', iv },
key,
encryptedData
);
const decoder = new TextDecoder();
return decoder.decode(decrypted);
}
// 生成密钥
async function generateKey() {
return await crypto.subtle.generateKey(
{ name: 'AES-GCM', length: 256 },
true,
['encrypt', 'decrypt']
);
}
3. 使用 RSA-OAEP 进行非对称加密
RSA 适合加密小数据或传输对称密钥:
async function generateRSAKeyPair() {
return aw
ait crypto.subtle.generateKey(
{
name: 'RSA-OAEP',
modulusLength: 2048,
publicExponent: new Uint8Array([1, 0, 1]),
hash: 'SHA-256'
},
true,
['encrypt', 'decrypt']
);
}
async function encryptWithPublicKey(data, publicKey) {
const encoder = new TextEncoder();
const encoded = encoder.encode(data);
return await crypto.subtle.encrypt(
{ name: 'RSA-OAEP' },
publicKey,
encoded
);
}
注意事项与限制
虽然 Web Cryptography API 功能强大,但使用时需注意以下几点:
- 必须在 HTTPS 环境下运行(本地开发可使用 localhost)
- 密钥通常不能以明文形式导出(尤其是标记为 extractable: false 时)
- API 返回的是 Promise,所有操作异步进行
- 不同浏览器对算法的支持略有差异,建议查阅兼容性表
- 避免在前端做敏感逻辑(如权限判断),加密主要用于保护传输或临时存储的数据
基本上就这些。Web Cryptography API 提供了一种标准化、安全的方式来处理加密任务,减少对第三方库的依赖,是现代 Web 安全的重要组成部分。
以上就是J*aScript加密算法_Web Cryptography API的详细内容,更多请关注其它相关文章!
# 加载
# 网站建设技艺
# 绍兴海外营销推广公司
# 阿克苏抖音seo全托管
# 远程指导网站建设活动
# 第二章 网站建设
# 银川网站建设哪家快些
# 大东区电子网站建设公司
# 济南品牌推广网站
# 西藏招聘网站优化
# seo优化最重要的环节
# 几个
# 加密解密
# 非对称
# javascript
# 的是
# 按需
# 如何用
# 第三方
# 管理器
# 如何使用
# crypto
# 数据加密
# ai
# 浏览器
# 前端
# java
相关栏目:
【
科技资讯46185 】
【
网络学院92790 】
相关推荐:
如何高效处理PHP中的Excel数据导入导出?PortPHP/Spreadsheet助你轻松搞定!
C++ string find函数返回值npos详解_C++字符串查找失败的判断条件
漫蛙Manwa2官网入口地址分享 漫蛙漫画PC版永久访问通道
2025-2030年全球乘用车销量预测:新能源成增长主力
C++如何实现线程池_C++11手动实现一个简单的固定大小线程池
手机CPU怎么影响游戏体验_手机CPU对游戏性能的影响分析
Windows电脑怎么截图最方便_系统自带截图工具的5种神仙用法【技巧】
UC浏览器官网入口2025最新 UC浏览器网页版正式地址
抖音隐秘迷城小游戏入口_ 抖音冒险解谜小游戏秒玩
如何有效阻止外部脚本意外修改内联样式的高度属性
yandex入口引擎手机版 yandex安卓版下载入口
蛙漫限时开放最深处链接_蛙漫全站漫画会员同款秒开地址
css卡片内容溢出如何处理_使用overflow隐藏或scroll显示内容
C#使用XPath查询节点时出错? 常见语法错误与调试技巧
Win11截图该按哪些键 Win11截屏完整流程解析【教程】
J*aScript实现动态背景色下的文本与按钮颜色自适应调整
拼多多赚钱渠道_拼多多收益来源
J*aScript中针对特定容器内图片动画的实现教程
QQ邮箱登录官网首页 腾讯QQ邮箱网页入口
神庙逃亡小游戏在线玩 神庙逃亡小游戏入口
快手网页版在线登录 快手网页版官网入口快速访问
J*aScript中如何高效提取对象指定属性
c++中为什么推荐使用using替代typedef_c++现代化类型别名
蛙漫2日版入口 WAMAN2(日版)无删减漫画官网链接
vivo浏览器自带的下载器速度慢怎么办 vivo浏览器提升文件下载速度的技巧
c++中的std::forward_list和std::list有什么不同_c++ forward_list与list区别分析
小红书商家版怎样在笔记嵌入商品卡路径_小红书商家版在笔记嵌入商品卡路径【挂载教程】
c++如何实现一个简单的软件渲染器_c++从零开始的3D图形学
必由学官方网站入口 必由学学生教师共用登录通道
微博网页版官方账号登录 微博网页版内容浏览使用指南
css链接悬停下划线样式如何自定义_使用::after结合content和transition
格力空气能E5故障代码是什么情况_格力空气能E5代码解析与应对措施
c++如何使用std::memory_order控制原子操作顺序_c++ C++11内存模型详解
sublime怎么预览Markdown渲染效果_Markdown Preview插件 for sublime教程
《铁拳8》黑皮辣妹新实机:元气满满的18岁少女!
Yandex搜索引擎一键访问入口_俄罗斯Yandex官网免登录
深入理解J*aScript Promise异步执行与微任务队列
PDF怎么合并PDF并保持格式_PDF合并文件保持排版教程
KFC早餐时段怎么领特惠代码_KFC早餐订餐优惠代码获取与使用说明
机器学习中对数变换预测结果的反向还原
QQ邮箱正确登录入口_QQ邮箱官方网站使用地址
抖音商城签到领现金是真的吗_抖音商城签到奖励与提现说明
深入理解Promise链:如何在catch后中断then的执行
在Go Martini框架中高效服务动态生成图像的实践指南
Lar*el递归关系中排除子孙节点的策略
2025AO3夸克浏览器通道_AO3手机HTTPS安全入口分享
为什么我的微信朋友圈看不到别人的更新_微信朋友圈更新显示异常解决方法
Python多版本共存与虚拟环境管理深度指南
《噬血代码2》新预告片发布 展示游戏剧情
在Go语言中利用后缀数组处理多字符串:实现高效文本匹配与自动补全


2025-11-25
浏览次数:次
返回列表
ait crypto.subtle.generateKey(
{
name: 'RSA-OAEP',
modulusLength: 2048,
publicExponent: new Uint8Array([1, 0, 1]),
hash: 'SHA-256'
},
true,
['encrypt', 'decrypt']
);
}
async function encryptWithPublicKey(data, publicKey) {
const encoder = new TextEncoder();
const encoded = encoder.encode(data);
return await crypto.subtle.encrypt(
{ name: 'RSA-OAEP' },
publicKey,
encoded
);
}