日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁 > 前端技术 > javascript >内容正文

javascript

node 加密解密模块_NODE.JS加密模块CRYPTO常用方法介绍

發(fā)布時(shí)間:2023/12/15 javascript 32 豆豆
生活随笔 收集整理的這篇文章主要介紹了 node 加密解密模块_NODE.JS加密模块CRYPTO常用方法介绍 小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

使用require('crypto')調(diào)用加密模塊。

加密模塊需要底層系統(tǒng)提供OpenSSL的支持。它提供了一種安全憑證的封裝方式,可以用于HTTPS安全網(wǎng)絡(luò)以及普通HTTP連接。

該模塊還提供了一套針對(duì)OpenSSL的hash(哈希),hmac(密鑰哈希),cipher(編碼),decipher(解碼),sign(簽名)以及verify(驗(yàn)證)等方法的封裝。

crypto.createCredentials(details)

創(chuàng)建一個(gè)憑證對(duì)象,可選參數(shù)details為一個(gè)帶鍵值的字典:

key:為字符串型,PEM編碼的私鑰。

cert:為字符串型,PEM編碼的認(rèn)證證書。

ca:字符串形式的PEM編碼可信CA證書,或證書列表。

如果沒有給出'ca'的詳細(xì)內(nèi)容,那么node.js將會(huì)使用默認(rèn)的公開受信任列表,該表位于http://mxr.mozilla.org/mozilla/source/security/nss/lib/ckfw/builtins/certdata.txt。

crypto.createHash(algorithm)

創(chuàng)建并返回一個(gè)hash對(duì)象,它是一個(gè)指定算法的加密hash,用于生成hash摘要。

參數(shù)algorithm可選擇系統(tǒng)上安裝的OpenSSL版本所支持的算法。例如:'sha1', 'md5', 'sha256', 'sha512'等。在近期發(fā)行的版本中,openssl list-message-digest-algorithms會(huì)顯示這些可用的摘要算法。

hash.update(data)

更新hash的內(nèi)容為指定的data。當(dāng)使用流數(shù)據(jù)時(shí)可能會(huì)多次調(diào)用該方法。

hash.digest(encoding='binary')

計(jì)算所有傳入數(shù)據(jù)的hash摘要。參數(shù)encoding(編碼方式)可以為'hex', 'binary' 或者'base64'。

crypto.createHmac(algorithm, key)

創(chuàng)建并返回一個(gè)hmac對(duì)象,它是一個(gè)指定算法和密鑰的加密hmac。

參數(shù)algorithm可選擇OpenSSL支持的算法 - 參見上文的createHash。參數(shù)key為hmac所使用的密鑰。

hmac.update(data)

更新hmac的內(nèi)容為指定的data。當(dāng)使用流數(shù)據(jù)時(shí)可能會(huì)多次調(diào)用該方法。

hmac.digest(encoding='binary')

計(jì)算所有傳入數(shù)據(jù)的hmac摘要。參數(shù)encoding(編碼方式)可以為'hex', 'binary' 或者'base64'。

crypto.createCipher(algorithm, key)

使用指定的算法和密鑰創(chuàng)建并返回一個(gè)cipher對(duì)象。

參數(shù)algorithm可選擇OpenSSL支持的算法,例如'aes192'等。在最近的發(fā)行版中,openssl list-cipher-algorithms會(huì)顯示可用的加密的算法。

cipher.update(data, input_encoding='binary', output_encoding='binary')

使用參數(shù)data更新要加密的內(nèi)容,其編碼方式由參數(shù)input_encoding指定,可以為 'utf8', 'ascii'或者'binary'。參數(shù)output_encoding指定了已加密內(nèi)容的輸出編碼方式,可以為 'binary', 'base64'或'hex'。

返回已加密的內(nèi)容,當(dāng)使用流數(shù)據(jù)時(shí)可能會(huì)多次調(diào)用該方法。

cipher.final(output_encoding='binary')

返回所有剩余的加密內(nèi)容,output_encoding輸出編碼為'binary', 'ascii'或'utf8'其中之一。

crypto.createDecipher(algorithm, key)

使用給定的算法和密鑰創(chuàng)建并返回一個(gè)解密對(duì)象。該對(duì)象為上述加密對(duì)象的反向運(yùn)算。

decipher.update(data, input_encoding='binary', output_encoding='binary')

使用參數(shù)data更新要解密的內(nèi)容,其編碼方式為'binary','base64'或'hex'。參數(shù)output_encoding指定了已解密的明文內(nèi)容的輸出編碼方式,可以為 'binary','ascii'或'utf8'。

decipher.final(output_encoding='binary')

返回全部剩余的已解密的明文,其output_encoding' 為'binary', 'ascii'或'utf8'`其中之一。

crypto.createSign(algorithm)

使用給定的算法創(chuàng)建并返回一個(gè)簽名器對(duì)象。在現(xiàn)有的OpenSSL發(fā)行版中,openssl list-public-key-algorithms會(huì)顯示可用的簽名算法,例如:'RSA-SHA256'。

signer.update(data)

使用data參數(shù)更新簽名器對(duì)象。當(dāng)使用流數(shù)據(jù)時(shí)可能會(huì)多次調(diào)用該方法。

signer.sign(private_key, output_format='binary')

對(duì)所有傳入簽名器的數(shù)據(jù)計(jì)算其簽名。private_key為字符串,它包含了PEM編碼的用于簽名的私鑰。

返回簽名,其output_format輸出可以為'binary', 'hex' 或者'base64'。

crypto.createVerify(algorithm)

使用給定算法創(chuàng)建并返回一個(gè)驗(yàn)證器對(duì)象。它是上述簽名器對(duì)象的反向運(yùn)算。

verifier.update(data)

使用data參數(shù)更新驗(yàn)證器對(duì)象。當(dāng)使用流數(shù)據(jù)時(shí)可能會(huì)多次調(diào)用該方法。

verifier.verify(cert, signature, signature_format='binary')

使用參數(shù)cert和signature驗(yàn)證已簽名的數(shù)據(jù),cert為經(jīng)過PEM編碼的公鑰字符串,signature為之前已計(jì)算的數(shù)據(jù)的簽名,signature_format可以為'binary','hex' 或者'base64'。

根據(jù)對(duì)數(shù)據(jù)和公鑰進(jìn)行簽名有效性驗(yàn)證的結(jié)果,返回true或者false。

當(dāng)你需要一個(gè)不可逆的加密代碼如何寫

var text = "123|12312312123123121231231212312312123123121231231212312312";

var hasher=crypto.createHash("md5");

hasher.update(text);

var hashmsg=hasher.digest('hex');//hashmsg為加密之后的數(shù)據(jù)

當(dāng)你需要一個(gè)加密和解密的環(huán)境時(shí)

var key="asdhjwheru*asd123-123";//加密的秘鑰

var text = "123|12312312123123121231231212312312123123121231231212312312";

var crypted =cipher.update(text,'utf8','hex');

crypted+=cipher.final('hex');

var message=crypted;//加密之后的值

var decipher = crypto.createDecipher('aes-256-cbc',key);

var dec=decipher.update(message,'hex','utf8');

dec+= decipher.final('utf8');//解密之后的值

PS:關(guān)于加密技術(shù),本站還提供了如下加密工具供大家參考使用:

總結(jié)

以上是生活随笔為你收集整理的node 加密解密模块_NODE.JS加密模块CRYPTO常用方法介绍的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。