首页 > web前端 > js教程 > 正文

javascript怎样进行数据加密和解密?_javascript的Web Crypto API如何使用?

幻影之瞳
发布: 2025-12-15 22:28:02
原创
364人浏览过
JavaScript无内置encrypt/decrypt函数,但现代浏览器支持Web Crypto API,提供AES-GCM等安全加密能力,需用crypto.getRandomValues生成IV,密钥默认不可导出,导出须用JWK格式并妥善保护。

javascript怎样进行数据加密和解密?_javascript的web crypto api如何使用?

JavaScript 本身不内置传统意义上的“加密函数”(比如 encrypt()decrypt()),但现代浏览器提供了标准、安全的 Web Crypto API,可用于对称加密(如 AES)、非对称加密(如 RSA)、哈希、密钥派生等。它替代了过去依赖第三方库(如 CryptoJS)的做法,且由浏览器原生支持、性能好、符合安全规范。

使用 Web Crypto API 进行 AES-GCM 加密与解密

AES-GCM 是目前推荐的对称加密方式,兼顾保密性、完整性与认证。注意:密钥不能硬编码,应安全生成并妥善管理。

  • 生成密钥crypto.subtle.generateKey("AES-GCM", true, ["encrypt", "decrypt"])
  • 加密数据:需提供密钥、随机 IV(12 字节推荐)、可选附加认证数据(AAD),返回加密后的 ArrayBuffer
  • 解密数据:用相同密钥、IV 和 AAD 调用 decrypt(),失败会抛出异常(如 IV 错误或密文被篡改)

示例关键步骤(省略 Promise 处理):

const iv = crypto.getRandomValues(new Uint8Array(12));
const encoded = new TextEncoder().encode("hello world");
const encrypted = await crypto.subtle.encrypt({ name: "AES-GCM", iv }, key, encoded);

如何安全地导入/导出密钥?

密钥默认不可导出(extractable: false),防止内存泄露。若需传输或存储,必须设为 true,并用 wrapKey/unwrapKey 配合另一个密钥保护(例如用 RSA-OAEP 封装 AES 密钥)。

Mureka
Mureka

Mureka是昆仑万维最新推出的一款AI音乐创作工具,输入歌词即可生成完整专属歌曲。

Mureka 1091
查看详情 Mureka

立即学习Java免费学习笔记(深入)”;

  • 导出为 JSON Web Key(JWK)格式:crypto.subtle.exportKey("jwk", key)
  • 从 JWK 导入:crypto.subtle.importKey("jwk", jwk, alg, true, usage)
  • 切勿用 JSON.stringify() 直接存裸密钥——JWK 中的 k 字段是 base64url 编码的原始密钥材料,仍需保密

常见误区和注意事项

  • 不要用 Math.random() 生成 IV 或盐值——必须用 crypto.getRandomValues()
  • TextEncoder/TextDecoder 只处理 UTF-8;二进制数据(如图片)直接操作 ArrayBuffer 即可
  • Web Crypto API 是异步的,所有方法返回 Promise,不能同步调用
  • 不支持 Node.js 默认环境(v15+ 可用内置 crypto 模块,API 不同)
  • 部分算法(如 RSA-PSS、ECDSA)仅在安全上下文(HTTPS 或 localhost)中可用

基本上就这些。Web Crypto API 功能完整但接口偏底层,写起来比 CryptoJS 略繁琐,但换来的是标准化与安全性。实际项目中可封装成简单函数(如 encryptAes(text, key)),避免重复处理编码/IV/错误逻辑。

以上就是javascript怎样进行数据加密和解密?_javascript的Web Crypto API如何使用?的详细内容,更多请关注php中文网其它相关文章!

java速学教程(入门到精通)
java速学教程(入门到精通)

java怎么学习?java怎么入门?java在哪学?java怎么学才快?不用担心,这里为大家提供了java速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号