登录
首页 >  文章 >  前端

JavaScript加密详解:WebCryptoAPI使用教程

时间:2026-01-05 15:16:07 339浏览 收藏

各位小伙伴们,大家好呀!看看今天我又给各位带来了什么文章?本文标题《JavaScript加密算法:Web Crypto API详解》,很明显是关于文章的文章哈哈哈,其中内容主要会涉及到等等,如果能帮到你,觉得很不错的话,欢迎各位多多点评和分享!

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

JavaScript加密算法_Web Cryptography API

Web Cryptography API 是现代浏览器提供的一套底层加密功能,允许开发者在客户端安全地执行常见的加密操作,比如生成密钥、加密解密数据、签名与验证、哈希计算等。它不依赖第三方库,直接通过 JavaScript 调用系统级加密模块,提升了安全性与性能。

支持的加密操作

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 加密与解密

对称加密适合加密大量数据,密钥需保密:

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 await 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 安全的重要组成部分。

终于介绍完啦!小伙伴们,这篇关于《JavaScript加密详解:WebCryptoAPI使用教程》的介绍应该让你收获多多了吧!欢迎大家收藏或分享给更多需要学习的朋友吧~golang学习网公众号也会发布文章相关知识,快来关注吧!

前往漫画官网入口并下载 ➜
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>