nodejs之utility,crypto使用

本章主要记录nodejs加密和验签等方法使用!

首先安装utility

npm install utility --save

  1. 使用utility进行MD5加密,添加以下代码运行
//utility.md5(date,format),format默认编码为hex,只能选hex或base64两种编码
var utility=require('utility');
var str='学习utility';
console.log(utility.md5(str));
console.log(utility.md5(str,'base64'));

控制台打印

7e344d996829ca1f8a67d98c36509c67
fjRNmWgpyh+KZ9mMNlCcZw==
  1. 使用utility进行sha1,sha256加密,添加以下代码运行
//utility.sha1(date,format),format默认编码为hex,只能选hex或base64两种编码
console.log(utility.sha1(str));
console.log(utility.sha1(str,'base64'));
console.log(utility.sha256(str));
console.log(utility.sha256(str,'base64'));

控制台打印

30614833a976e402557f1623b92596ad3430983c
MGFIM6l25AJVfxYjuSWWrTQwmDw=
6496e8ee074c100f9e36d64c651139af60051870f734499bc5d1865cc4798710
ZJbo7gdMEA+eNtZMZRE5r2AFGHD3NEmbxdGGXMR5hxA=
  1. 使用hmac加密,添加以下代码运行
/** 
 * utility.hmac(algorithm, key, data, encoding),
 * algorithm可选'sha1', 'md5', 'sha256', 'sha512'等,
 * key就是你的密钥,data是待加密字符串
 * encoding默认编码为base64
*/
console.log(utility.hmac('sha1', 'mykey', str));
console.log(utility.hmac('md5', 'mykey', str));
console.log(utility.hmac('sha256', 'mykey', str));
console.log(utility.hmac('sha512', 'mykey', str));

控制台打印

Yd5J6uu2ca/FJD07ijG+waj64gU=
8KMoG97snj7yaRKUc3gHag==
ZcYWgYo7B3AEWZlPO48hogMW4Ga7tIr2UWoTLDgXt7c=
murQi+N4d9s/YNc/F7Sjlp09OEgOqCm1daPsxl6ey+wQUIZj+z7ELv5UN7ILHrmRno2lDsbfeslRE32I/e7CmA==
  1. 使用utility进行base64,uri编码解码
console.log(utility.base64encode(str));
console.log(utility.base64encode('5a2m5LmgdXRpbGl0eQ=='));
console.log(utility.encodeURIComponent(str));
console.log(utility.decodeURIComponent('%E5%AD%A6%E4%B9%A0utility'));

控制台打印

5a2m5LmgdXRpbGl0eQ==
NWEybTVMbWdkWFJwYkdsMGVRPT0=
%E5%AD%A6%E4%B9%A0utility
学习utility

utility的常用加密,编码就这些,它还有一些其他的方法,例如对数字,字符串,时间,json等的操作,它其实就是一个封装好的工具库,从它的源码可以看出来
在这里插入图片描述

但是有些加密utility是没有的,比如rsa,这里就要用到crypto这个库了
首先安装crypto

npm install crypto --save

  1. 使用openssl生成公钥私钥(openssl可以网上查询)
//私钥
var privatekey = '-----BEGIN PRIVATE KEY-----\n' +
  'MIICeAIBADANBgkqhkiG9w0BAQEFAASCAmIwggJeAgEAAoGBAMlNpwKSz+AIOk+1\n' +
  'ChNSaoWTtGVgGPsF6eTMnqun+RPsElua0NBPNcpO0AeoAi8oy8S/ouVQrZOQtYcK\n' +
  'i+wJCa3iHRlAHbuhXfkyNB2iIR4j4kNonDico2L3qUA7Do21EOAfhJK4r10WR5u2\n' +
  'RL4OEAwrgMU3CzG1z41nHnz7u1UHAgMBAAECgYBIxn8Daiom1zKlkFDFLX1/Lyf/\n' +
  'ol9FmRy279bJPh/JOQZmAbFOLeTHb/i7W9z2SaxpQ9LTTniCKcXGvWRaf+X0R0bs\n' +
  'c6XNIVT93QPqyLs2xJzzUKaFdMz3HPDbAP+8lllMylwhntxjNaPbzdI8Lo3ejR1U\n' +
  'cmZmk+7Mrg9guomBuQJBAPhLFa+uio4POdDM96VVs74cYzfEQf2fX2ZU2Xqcwg1j\n' +
  'sMasxwfVRwijVQyi1hSVgr5dEelKtTnDYH0DSu3SJ2MCQQDPjTCU+v+ZM0pPPgb1\n' +
  'rJg+mPXseNuP8DWjdeswT2s7N+V/1q7XhcDYgKiJY+hgZ8dGDHa+y1AgfmXj3waC\n' +
  '9+cNAkEAnSLHwrtvrKAuMtrFD7nBW1uT30MxkFVAhv7D9DkpBlhFFDdcbrSnk+vq\n' +
  'c2jKm5RTfi5gm4hQURI5CmT/EquhiQJBAM1+NiabKKwPOzif6hYdr5LysTJTKtgl\n' +
  'dYYE/zoSt9Gm8yQSc4PR2vDA2Z1F/NJOjd9OAde/xvKVEt59d53+QpUCQQCP19nK\n' +
  'PQ/0i0bI9MUX/mCmwdP858qOTs5FaI2SYZsMQHmrUifYaqywb5Bic3Pnkx+PChoG\n' +
  'SYwwOBHsSne17RiQ\n' +
  '-----END PRIVATE KEY-----';
//公钥
var publickey = '-----BEGIN PUBLIC KEY-----\n' +
  'MIGfMA0GCSqGSIb3DQEBAQUAA4GNADCBiQKBgQDJTacCks/gCDpPtQoTUmqFk7Rl\n' +
  'YBj7BenkzJ6rp/kT7BJbmtDQTzXKTtAHqAIvKMvEv6LlUK2TkLWHCovsCQmt4h0Z\n' +
  'QB27oV35MjQdoiEeI+JDaJw4nKNi96lAOw6NtRDgH4SSuK9dFkebtkS+DhAMK4DF\n' +
  'Nwsxtc+NZx58+7tVBwIDAQAB\n' +
  '-----END PUBLIC KEY-----';
  1. 生成签名,这里以RSA-SHA1为例
var signer = crypto.createSign("RSA-SHA1");
signer.update(str);
var sign = signer.sign(privatekey, "base64");
  1. 验签
var verifier = crypto.createVerify("RSA-SHA1");
verifier.update(str);
var result = verifier.verify(publickey, sign, "base64");
console.log(sign);
console.log(result);
  1. 运行之后,控制台打印
i15f8HkBVhfVjhojdkK1hrGwe3PKHLE67SsNTTtdm6Zxw1ww9F5l
FEzWO2pD+60UuLCRfTUH33DoNoFri+Z+QeXRFPu9Ap6kd3CR
+P7DV8Tsxa9oQio0qJ+Y0Zqv9gUoyqOBNiX8phlCGn42eHGgOdgN7UZoM6o
khBlbZOVn9fY=
true

crypto文档地址:http://nodejs.cn/api/crypto.html

上一篇:nodejs之日志管理
下一篇:nodejs之nginx学习

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Node.js 中的 crypto 是一个内置模块,用于提供加密和解密功能。它支持各种加密算法和操作,包括哈希函数、对称加密和非对称加密。你可以使用 crypto 模块来实现数据的加密、解密、签名和验证等操作。 要使用 crypto 模块,你需要在你的代码中引入它,例如: ```javascript const crypto = require('crypto'); ``` 一些常见的 crypto 操作包括: 1. 哈希函数:crypto 模块提供了多个哈希函数,如 MD5、SHA-1、SHA-256 等。你可以使用这些函数对数据进行哈希处理,生成唯一的摘要。例如: ```javascript const hash = crypto.createHash('sha256'); hash.update('Hello, world!'); const digest = hash.digest('hex'); console.log(digest); // 输出生成的摘要 ``` 2. 对称加密crypto 模块支持对称加密算法,如 AES、DES、3DES 等。你可以使用这些算法对数据进行加密和解密。例如: ```javascript const cipher = crypto.createCipher('aes192', 'password'); let encrypted = cipher.update('Hello, world!', 'utf8', 'hex'); encrypted += cipher.final('hex'); console.log(encrypted); // 输出加密后的数据 const decipher = crypto.createDecipher('aes192', 'password'); let decrypted = decipher.update(encrypted, 'hex', 'utf8'); decrypted += decipher.final('utf8'); console.log(decrypted); // 输出解密后的数据 ``` 3. 非对称加密crypto 模块还支持非对称加密算法,如 RSA。你可以使用这些算法生成公钥和私钥,进行加密和解密。例如: ```javascript const { publicKey, privateKey } = crypto.generateKeyPairSync('rsa', { modulusLength: 4096, publicKeyEncoding: { type: 'spki', format: 'pem' }, privateKeyEncoding: { type: 'pkcs8', format: 'pem' } }); console.log(publicKey); // 输出生成的公钥 console.log(privateKey); // 输出生成的私钥 const encrypted = crypto.publicEncrypt(publicKey, Buffer.from('Hello, world!')); console.log(encrypted.toString('base64')); // 输出加密后的数据 const decrypted = crypto.privateDecrypt(privateKey, encrypted); console.log(decrypted.toString('utf8')); // 输出解密后的数据 ``` 这只是 crypto 模块的一小部分功能,你可以查阅 Node.js 文档以获取更详细的信息和使用方法。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值