0

0

JavaScript加密算法_非对称加密实现

狼影

狼影

发布时间:2025-11-22 22:32:02

|

381人浏览过

|

来源于php中文网

原创

非对称加密使用公钥加密、私钥解密,常用于前端敏感数据传输保护。JavaScript可通过jsencrypt库或Web Crypto API实现RSA加密,前者使用PKCS#1 v1.5填充,安全性有限;后者支持RSA-OAEP,更安全且无需第三方库。前端用公钥加密小量数据(如对称密钥),后端用私钥解密,需确保填充方式一致,私钥不暴露,配合HTTPS防重放攻击。Web Crypto API为现代推荐方案,需将PEM公钥转为DER格式导入。

javascript加密算法_非对称加密实现

非对称加密在JavaScript中通常用于安全通信场景,比如前端与后端之间的敏感数据传输。虽然浏览器环境不原生提供完整的加密算法库,但可以通过第三方库如 jsencryptcrypto-js(部分支持)来实现。最常用的非对称加密算法是RSA。

什么是非对称加密

非对称加密使用一对密钥:公钥和私钥。公钥可以公开,用于加密数据;私钥必须保密,用于解密。这意味着任何人可以用你的公钥加密信息,但只有你用私钥才能解密。

RSA 是最广泛使用的非对称加密算法之一,适合在JavaScript中实现前端加密、后端解密的模式。

使用 jsencrypt 实现 RSA 加密

注意:jsencrypt 内部使用的是较老版本的RSA填充(PKCS#1 v1.5),安全性有限,仅适用于一般保护,不建议用于高安全要求场景。

步骤如下:

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

  • 引入 jsencrypt 库
  • 生成或使用已有的 RSA 公私钥对
  • 使用公钥加密数据
  • 将密文发送到服务端,用私钥解密

1. 引入 jsencrypt(通过CDN或npm):

<script src="https://cdnjs.cloudflare.com/ajax/libs/jsencrypt/2.3.1/jsencrypt.min.js"></script>

2. 使用公钥加密字符串:

const encrypt = new JSEncrypt();
encrypt.setPublicKey(`-----BEGIN PUBLIC KEY-----
MIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEAuMXE...
-----END PUBLIC KEY-----`);
<p>const plaintext = "hello world";
const encrypted = encrypt.encrypt(plaintext);
console.log("密文:", encrypted); // 输出 Base64 编码的密文

3. 后端(如Node.js + crypto模块)使用私钥解密:

Nanonets
Nanonets

基于AI的自学习OCR文档处理,自动捕获文档数据

下载
const crypto = require('crypto');
<p>const privateKey = <code>-----BEGIN RSA PRIVATE KEY----- MIIEowIBAAKCAQEAuMXE... -----END RSA PRIVATE KEY-----</code>;</p><p>const decrypted = crypto.privateDecrypt(
{
key: privateKey,
padding: crypto.constants.RSA_PKCS1_PADDING
},
Buffer.from(encrypted, 'base64')
);</p><p>console.log(decrypted.toString()); // 输出: hello world

常见问题与注意事项

非对称加密在前端使用时有几点需要特别注意:

  • 性能限制:RSA 只适合加密小量数据(如加密一个对称密钥),不能加密大段文本
  • 密钥管理:私钥绝不能暴露在前端代码中
  • 填充方式:确保前后端使用相同的填充方案(如 PKCS#1 v1.5)
  • 安全性:前端加密不能替代HTTPS,应配合TLS使用
  • 避免重放攻击:可加入时间戳或随机数防止密文被重复利用

现代替代方案:Web Crypto API

现代浏览器支持更安全的 Web Crypto API,原生支持RSA等非对称加密操作,无需第三方库。

它支持生成密钥对、加密、解密、签名和验证,且更安全,推荐用于新项目。

示例:使用 Web Crypto API 进行 RSA-OAEP 加密

async function encryptWithPublicKey(data, publicKeyPem) {
  const binaryDer = convertPemToBinary(publicKeyPem);
  const cryptoKey = await crypto.subtle.importKey(
    "spki",
    binaryDer,
    { name: "RSA-OAEP", hash: "SHA-256" },
    true,
    ["encrypt"]
  );
<p>const encoder = new TextEncoder();
const encodedData = encoder.encode(data);</p><p>const encrypted = await crypto.subtle.encrypt(
{ name: "RSA-OAEP" },
cryptoKey,
encodedData
);</p><p>return btoa(String.fromCharCode(...new Uint8Array(encrypted)));
}

注意:Web Crypto API 对密钥格式要求较高,需将 PEM 转为二进制 DER 格式。

基本上就这些。非对称加密在前端主要用于保护敏感字段(如密码、身份证号),核心思想是“前端加密、后端解密”,保障传输过程中的数据安全。选择合适工具,注意密钥和填充方式一致性,才能有效实现。不复杂但容易忽略细节。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

WorkBuddy
WorkBuddy

腾讯云推出的AI原生桌面智能体工作台

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
js 字符串转数组
js 字符串转数组

js字符串转数组的方法:1、使用“split()”方法;2、使用“Array.from()”方法;3、使用for循环遍历;4、使用“Array.split()”方法。本专题为大家提供js字符串转数组的相关的文章、下载、课程内容,供大家免费下载体验。

760

2023.08.03

js截取字符串的方法
js截取字符串的方法

js截取字符串的方法有substring()方法、substr()方法、slice()方法、split()方法和slice()方法。本专题为大家提供字符串相关的文章、下载、课程内容,供大家免费下载体验。

221

2023.09.04

java基础知识汇总
java基础知识汇总

java基础知识有Java的历史和特点、Java的开发环境、Java的基本数据类型、变量和常量、运算符和表达式、控制语句、数组和字符串等等知识点。想要知道更多关于java基础知识的朋友,请阅读本专题下面的的有关文章,欢迎大家来php中文网学习。

1567

2023.10.24

字符串介绍
字符串介绍

字符串是一种数据类型,它可以是任何文本,包括字母、数字、符号等。字符串可以由不同的字符组成,例如空格、标点符号、数字等。在编程中,字符串通常用引号括起来,如单引号、双引号或反引号。想了解更多字符串的相关内容,可以阅读本专题下面的文章。

649

2023.11.24

java读取文件转成字符串的方法
java读取文件转成字符串的方法

Java8引入了新的文件I/O API,使用java.nio.file.Files类读取文件内容更加方便。对于较旧版本的Java,可以使用java.io.FileReader和java.io.BufferedReader来读取文件。在这些方法中,你需要将文件路径替换为你的实际文件路径,并且可能需要处理可能的IOException异常。想了解更多java的相关内容,可以阅读本专题下面的文章。

1228

2024.03.22

php中定义字符串的方式
php中定义字符串的方式

php中定义字符串的方式:单引号;双引号;heredoc语法等等。想了解更多字符串的相关内容,可以阅读本专题下面的文章。

1204

2024.04.29

go语言字符串相关教程
go语言字符串相关教程

本专题整合了go语言字符串相关教程,阅读专题下面的文章了解更多详细内容。

193

2025.07.29

c++字符串相关教程
c++字符串相关教程

本专题整合了c++字符串相关教程,阅读专题下面的文章了解更多详细内容。

131

2025.08.07

Python异步编程与Asyncio高并发应用实践
Python异步编程与Asyncio高并发应用实践

本专题围绕 Python 异步编程模型展开,深入讲解 Asyncio 框架的核心原理与应用实践。内容包括事件循环机制、协程任务调度、异步 IO 处理以及并发任务管理策略。通过构建高并发网络请求与异步数据处理案例,帮助开发者掌握 Python 在高并发场景中的高效开发方法,并提升系统资源利用率与整体运行性能。

37

2026.03.12

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
React 教程
React 教程

共58课时 | 6万人学习

TypeScript 教程
TypeScript 教程

共19课时 | 3.4万人学习

Bootstrap 5教程
Bootstrap 5教程

共46课时 | 3.6万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

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