RSA加密算法

写在前面:

了解RSA算法的原理请查看下面的文章

一文搞懂 RSA 算法  来源:简书  作者:somenzz

在使用 Node 进行 RSA 加密之前我们首先需要获取RSA公共和私有密钥:

1.下载 OpenSSL

两个网址:一个是 官方网站 ,另一个是社区整理网站

2.安装 OpenSSL ,查看下面的文章

OpenSSL下载安装  来源:简书  作者:涓涓细流_708d

3.使用 OpenSSL 生成 RSA 密钥

a.打开命令行,进入到安装OpenSSL的bin目录下(我的是默认安装到C盘)

cd C:\OpenSSL-Win64\bin

在命令行中执行

openssl genrsa -aes256 -out rsa-key.pem 2048

上面命令的意思是使用 aes256 进行加密,加密密钥长度为 2048 位,并将结果输出到 res-key.pem 文件中,默认将生成的文件输出到 bin 目录下

执行完后是需要输入密码的,这个密码是用来对RSA密钥加密的

b.通过上面的加密文件 rsa-key.pem 生成私有密钥 rsa-prv.pem

openssl rsa -in rsa-key.pem -outform PEM -out rsa-prv.pem

输入之前生成加密文件时输入的密码

c.生成公共密钥 rsa-pub.pem

openssl rsa -in rsa-key.pem -outform PEM -pubout -out rsa-pub.pem

通过上面生成的步骤生成私钥和公钥后,我们就可以使用Node的方式对文件进行rsa加密

使用 Node 对文件进行 RSA 加密:

'use strict';
const crypto = require('crypto');
const fs = require('fs');

//定义一个同步读取文件的方法
let getFile = (file) => {
    try {
        let pubKey = fs.readFileSync(file, 'utf-8');
        return pubKey;
    } catch(err) {
        console.log(err);
        return false;
    }
}

//读取rsa公钥
let pubKey = getFile('./rsa-pub.pem');
//读取rsa加密私钥
let prvKey = getFile('./rsa-prv.pem');
//读取需要加密的文件
let data = getFile('./data.txt');

//使用私钥加密,公钥解密
const prv_enCrypt = crypto.privateEncrypt(prvKey, Buffer.from(data, 'utf-8') );
const pub_deCrypt = crypto.publicDecrypt(pubKey, prv_enCrypt, 'utf-8');

console.log('使用私钥加密之后的文件: ' + prv_enCrypt.toString('hex'));
console.log('使用公钥解密之后的文件: ' + pub_deCrypt.toString());

//除了可以使用私钥加密公钥解密外还可以使用私钥加密公钥解密
const pub_enCrypt = crypto.publicEncrypt(pubKey, Buffer.from(data, 'utf-8'));
const prv_deCrypt = crypto.privateDecrypt(prvKey, pub_enCrypt);

console.log('使用公钥加密之后的文件: ' + pub_enCrypt.toString('hex'));
console.log('使用私钥解密之后的文件: ' + prv_deCrypt.toString());

//加密后的文件使用fs(文件系统模块)导出
let exEncryptFile = fs.createWriteStream('./exEncryptFile.txt')
exEncryptFile.write( prv_enCrypt.toString('hex') );
exEncryptFile.end();

注:

1.RSA的加密方法的第二个参数需要传入 buffer 类型的数据

2.data.txt 文件是在同一目录下需要加密的文件,记得在执行上面代码的时候创建一个需要加密的文件

3.RSA加密方法即可以使用公钥加密私钥解密,也可以使用私钥加密公钥解密

Node.js 内置模块crypto加密模块(5) RSA的更多相关文章

  1. Node.js 内置模块crypto加密模块(4) Diffie Hellman

    Diffie-Hellman( DH ):密钥交换协议/算法 ( Diffie-Hellman Key Exchange/Agreement Algorithm ) 百科摘录: Diffie-Hell ...

  2. Node.js 内置模块crypto加密模块(3) HMAC

    HMAC:哈希消息认证码 ( Hash-based Message Authentication Code ) HMAC是密钥相关的哈希算法 使用 HMAC 进行加密的Node实现的一种方法: &qu ...

  3. Node.js 内置模块crypto加密模块(2) AES

    AES:高级加密标准 ( Advanced Encryption Standard ) AES是一种对称加密算法:加密需要密钥,且加密密钥和解密密钥相同 下面是AES加密的Node实现: " ...

  4. Node.js 内置模块crypto加密模块(1) MD5 和 SHA

    MD5:消息摘要算法(Message-Digest Algorithm) SHA家族:安全散列算法( Secure Hash Algorithm ) 1.首先看一个简单的加密 "use st ...

  5. Node.js 内置模块crypto使用事件方法(onreadable)加密的一些问题

    javaScript代码如下: 'use strict'; const crypto = require('crypto'); //实例化一个AES加密对象 const aesEncrept = cr ...

  6. [Node.js] Gzip + crypto in stream

    We can using gzip and crypto with stream: const fs = require('fs') const zlib = require('zlib') cons ...

  7. Node.js 内置模块fs(文件系统)

    fs模块的三个常用方法 1.fs.readFile() -- 读文件 2.fs.writeFile() -- 写文件 3.fa.stat() -- 查看文件信息 fs模块不同于其它模块的地方是它有异步 ...

  8. Node.js 内置模块fs的readdir方法 查看某个文件夹里面包含的文件内容

    fs.readdir(path[, options], callback) 例: "use strict"; const fs = require("fs"); ...

  9. Node.js 内置模块Stream(流)

    "流"是一种抽象的数据结构 通过使用"流"可以将一段数据分割成几段,并按顺序传输,使用"流"可以降低对系统性能的要求,减少对CPU的消耗 S ...

随机推荐

  1. Redmine后台修改admin密码

    Redmine后台修改admin密码 进入redmine安装目录,假设redmine安装在/var/www/html/redmine/目录下. cd /var/www/html/redmine/scr ...

  2. 51nod 1533 && CF538F

    题目:难以简述,请传送门 神犇题解Ⅰ   神犇题解Ⅱ 好劲啊跪在地上..完全没接触过K叉树的性质.. 对于每个询问,我们并不关心叶节点,只关心其他的节点.而一个完整K叉树的内节点个数是O(n/k)的, ...

  3. 算法(Algorithms)第4版 练习 1.3.10

    主要思路:和1.3.9相似,只不过运算表达式的生成方式不一样 用Dijkstra的双栈算法. 遇到数字则压入数字栈中(String). 遇到运算符则压入运算符栈中(String). 遇到右括号时,从数 ...

  4. CSS3实现水位充满文字特效

    CSS3实现水位充满文字特效是一款既是Loading特效也是文字特效,Loading动画开始时,文字中的水位渐渐上升,为了模拟水位上升的真实效果,水面还会波浪浮动,当Loading动画结束时,文字中的 ...

  5. not in和not exist的区别(转)

    in和exists in 是把外表和内表作hash 连接,而exists是对外表作loop循环,每次loop循环再对内表进行查询.一直以来认为exists比in效率高的说法是不准确的. 如果查询的两个 ...

  6. Unity-2017.2官方实例教程Roll-a-ball(二)

    声明: 本文系转载,由于Unity版本不同,文中有一些小的改动,原文地址:http://www.jianshu.com/p/97b630a23234 上一节Unity-2017.2官方实例教程Roll ...

  7. 远程调用appium server

    例如:我有两台电脑A(192.168.112.10)和B(192.168.112.11),那我怎么能在A执行本地脚本,但是使用B上的server呢?   查看appium连接appium服务并开启一个 ...

  8. unbuntu下安装qq

    由于Wine QQ一直没更新版本导致目前版本报版本过低无法使用,暂时先上UK官网的国际版Wine QQ,虽然功能没那么新,但稳定能用: 下载: 下载地址:http://www.ubuntukylin. ...

  9. ACM学习历程—Codeforces 446C DZY Loves Fibonacci Numbers(线段树 && 数论)

    Description In mathematical terms, the sequence Fn of Fibonacci numbers is defined by the recurrence ...

  10. /boot下面文件说明

    config-3.10.0-229.el7.x86_64 <==此版本核心被编译时选择的功能与模组设定档 grub/ <==旧版 grub1 ,不需要理会这目录了! grub2/ < ...