crypto
是node.js
中實現加密和解密的模塊 在node.js
中,使用OpenSSL
類庫做爲內部實現加密解密的手段 OpenSSL
是一個通過嚴格測試的可靠的加密與解密算法的實現工具html
散列算法也叫哈希算法,用來把任意長度的輸入變換成固定長度的輸出,常見的有md5,sha1等算法
console.log(crypto.getHashes());
複製代碼
crypto.createHash(algorithm);//建立HASH對象
hash.update(data,[input_encoding]);//增長要添加摘要的數據,摘要輸出前可使用屢次update
hash.digest([encoding]);//輸出摘要內容,輸出後則不能再添加摘要內容
複製代碼
var crypto = require('crypto');
var md5 = crypto.createHash('md5');//返回哈希算法
var md5Sum = md5.update('hello');//指定要摘要的原始內容,能夠在摘要被輸出以前使用屢次update方法來添加摘要內容
var result = md5Sum.digest('hex');//摘要輸出,在使用digest方法以後不能再向hash對象追加摘要內容。
console.log(result);
複製代碼
屢次updatewindows
var fs = require('fs');
var shasum = crypto.createHash('sha1');//返回sha1哈希算法
var rs = fs.createReadStream('./readme.txt');
rs.on('data', function (data) {
shasum.update(data);//指定要摘要的原始內容,能夠在摘要被輸出以前使用屢次update方法來添加摘要內容
});
rs.on('end', function () {
var result = shasum.digest('hex');//摘要輸出,在使用digest方法以後不能再向hash對象追加摘要內容。
console.log(result);
})
複製代碼
HMAC算法將散列算法與一個密鑰結合在一塊兒,以阻止對簽名完整性的破壞bash
let hmac crypto.createHmac(algorithm,key);
hmac.update(data);
複製代碼
PEM是OpenSSL的標準格式,OpenSSL使用PEM文件格式存儲證書和密鑰,是基於Base64編碼的證書。網絡
$ openssl genrsa -out rsa_private.key 1024
複製代碼
let pem = fs.readFileSync(path.join(__dirname, './rsa_private.key'));
let key = pem.toString('ascii');
let hmac = crypto.createHmac('sha1', key);
let rs = fs.createReadStream(path.join(__dirname, './1.txt'));
rs.on('data', function (data) {
hmac.update(data);
});
rs.on('end', function () {
let result = hmac.digest('hex');
console.log(result);
});
複製代碼
var crypto = require('crypto');
var fs = require('fs');
let str = 'hello';
let cipher = crypto.createCipher('blowfish', fs.readFileSync(path.join(__dirname, 'rsa_private.key')));
let encry = cipher.update(str, 'utf8','hex');
encry += cipher.final('hex');
console.log(encry);
let deciper = crypto.createDecipher('blowfish', fs.readFileSync(path.join(__dirname, 'rsa_private.key')));
let deEncry = deciper.update(encry, 'hex','utf8');
deEncry += deciper.final('utf8');
console.log(deEncry);
複製代碼
爲私鑰建立公鑰工具
openssl rsa -in rsa_private.key -pubout -out rsa_public.key
複製代碼
var crypto = require('crypto');
var fs = require('fs');
let key = fs.readFileSync(path.join(__dirname, 'rsa_private.key'));
let cert = fs.readFileSync(path.join(__dirname, 'rsa_public.key'));
let secret = crypto.publicEncrypt(cert, buffer);//公鑰加密
let result = crypto.privateDecrypt(key, secret);//私鑰解密
console.log(result.toString());
複製代碼
在網絡中,私鑰的擁有者能夠在一段數據被髮送以前先對數據進行簽名獲得一個簽名 經過網絡把此數據發送給數據接收者以後,數據的接收者能夠經過公鑰來對該簽名進行驗證,以確保這段數據是私鑰的擁有者所發出的原始數據,且在網絡中的傳輸過程當中未被修改。測試
let private = fs.readFileSync(path.join(__dirname, 'rsa_private.key'), 'ascii');
let public = fs.readFileSync(path.join(__dirname, 'rsa_public.key'), 'ascii');
let str = 'zhufengpeixun';
let sign = crypto.createSign('RSA-SHA256');
sign.update(str);
let signed = sign.sign(private, 'hex');
let verify = crypto.createVerify('RSA-SHA256');
verify.update(str);
let verifyResult = verify.verify(public,signed,'hex'); //true複製代碼