nodejs加密的方法:1、導入crypto模組;2、設定加密類型和要使用的加密金鑰;3、將編碼方式從utf-8轉為hex;4、回傳加密後的字符串即可。
本文操作環境:windows7系統、nodejs10.16.2版,DELL G3電腦。
nodejs 如何加密?
nodejs常用加密方式:
/** * @加密模块 * @md5可以被彩虹吧破解,这里就不用啦 * @author lwt * */ //导入模块 var crypto = require('crypto'); /** * @aes192加密模块 * @param str string 要加密的字符串 * @param secret string 要使用的加密密钥(要记住,不然就解不了密啦) * @retrun string 加密后的字符串 * */ exports.getEncAse192 = function(str, secret) { var cipher = crypto.createCipher("aes192", secret); //设置加密类型 和 要使用的加密密钥 var enc = cipher.update(str, "utf8", "hex"); //编码方式从utf-8转为hex; enc += cipher.final("hex"); //编码方式从转为hex; return enc; //返回加密后的字符串 } /** * @aes192解密模块 * @param str string 要解密的字符串 * @param secret string 要使用的解密密钥(要和密码的加密密钥对应,不然就解不了密啦) * @retrun string 解密后的字符串 * */ exports.getDecAse192 = function(str, secret) { var decipher = crypto.createDecipher("aes192", secret); var dec = decipher.update(str, "hex", "utf8");//编码方式从hex转为utf-8; dec += decipher.final("utf8");//编码方式从utf-8; return dec; } /** * @Hmac-sha1加密模块 (每次加密随机,不可逆) * @param str string 要加密的字符串 * @param secret string 要使用的加密密钥 * @retrun string 加密后的字符串 * */ exports.getHmac = function(str, secret) { var buf = crypto.randomBytes(16); secret = buf.toString("hex");//密钥加密; var Signture = crypto.createHmac("sha1", secret);//定义加密方式 Signture.update(str); var miwen=Signture.digest().toString("base64");//生成的密文后将再次作为明文再通过pbkdf2算法迭代加密; return miwen; } /** * @sha1加密模块 (加密固定,不可逆) * @param str string 要加密的字符串 * @retrun string 加密后的字符串 * */ exports.getSha1 = function(str) { var sha1 = crypto.createHash("sha1");//定义加密方式:md5不可逆,此处的md5可以换成任意hash加密的方法名称; sha1.update(str); var res = sha1.digest("hex"); //加密后的值d return res; }
加密是以某種演算法改變原有的信息數據,使得未授權用戶即使獲得了已加密訊息,因不知解密的方法,無法得知資訊的真正意義,透過這種方式提高網路資料傳輸的安全性,加密演算法常見的有雜湊演算法、HMAC 演算法、簽章、對稱性加密演算法和非對稱性加密演算法,加密演算法也分為可逆與不可逆,例如 md5 就是不可逆加密,只能暴力破解(撞擊庫),我們在NodeJS 開發中就是直接使用這些加密演算法,crypto 模組提供了加密功能,包含對 OpenSSL 的哈希、HMAC、加密、解密、簽章以及驗證功能的一整套封裝,核心模組,使用時不需安裝。
【推薦學習:《nodejs影片教學》】
以上是nodejs 如何加密的詳細內容。更多資訊請關注PHP中文網其他相關文章!