时间:2021-05-26
常见的加密算法基本分为这几类,1 :线性散列算法、2:对称性加密算法、3、非对称性加密算法 (记记记)
线性散列算法(签名算法):MD5,SHA1,HMAC
比如MD5:即Message-Digest Algorithm 5(信息-摘要算法5),用于确保信息传输完整一致。
特点:
1、压缩性:任意长度的数据,算出的MD5值长度都是固定的。
2、容易计算:从原数据计算出MD5值很容易。
3、抗修改性:对原数据进行任何改动,哪怕只修改1个字节,所得到的MD5值都有很大区别。
4、强抗碰撞:已知原数据和其MD5值,想找到一个具有相同MD5值的数据(即伪造数据)是非常困难的。
MD5的作用是让大容量信息在用数字签名软件签署私人密钥前被"压缩"成一种保密的格式(就是把一个任意长度的字节串变换成一定长的十六进制数字串)
对称性加密算法:AES,DES,3DES
比如AES:(Advanced Encryption Standard)在密码学中又称Rijndael加密法,是美国联邦政府采用的一种区块加密标准。这个标准用来替代原先的DES,已经被多方分析且广为全世界所使用。
非对称性加密算法:RSA,DSA,ECC
比如RSA:RSA公开密钥密码体制。所谓的公开密钥密码体制就是使用不同的加密密钥与解密密钥,是一种“由已知加密密钥推导出解密密钥在计算上是不可行的”密码体制。
在公开密钥密码体制中,加密密钥(即公开密钥)PK是公开信息,而解密密钥(即秘密密钥)SK是需要保密的。加密算法E和解密算法D也都是公开的。虽然解密密钥SK是由公开密钥PK决定的,但却不能根据PK计算出SK。
NodeJS中的Crypto模块
node利用 OpenSSL库来实现它的加密技术,这是因为OpenSSL已经是一个广泛被采用的加密算法。它包括了类似MD5 or SHA-1 算法,这些算法你可以利用在你的应用中。
下面的代码使用Crypto模块DES算法的实现方法
/*** * @author chenjianxiang * @date 2016-07-07 */var crypto = require('crypto');var key = '12345670';exports.des = { algorithm:{ ecb:'des-ecb',cbc:'des-cbc' }, encrypt:function(plaintext,iv){ var key = new Buffer(key); var iv = new Buffer(iv ? iv : 0); var cipher = crypto.createCipheriv(this.algorithm.ecb, key, iv); cipher.setAutoPadding(true) //default true var ciph = cipher.update(plaintext, 'utf8', 'base64'); ciph += cipher.final('base64'); return ciph; }, decrypt:function(encrypt_text,iv){ var key = new Buffer(key); var iv = new Buffer(iv ? iv : 0); var decipher = crypto.createDecipheriv(this.algorithm.ecb, key, iv); decipher.setAutoPadding(true); var txt = decipher.update(encrypt_text, 'base64', 'utf8'); txt += decipher.final('utf8'); return txt; }};使用DES加密解密方法
//加密var cryptUtil = require("./utils/crypt");var str = "/upload/image/201602120012.jpg";var encrypt_text = cryptUtil.des.encrypt(str,0);var decrypt_text = cryptUtil.des.decrypt(encrypt_text,0);console.log(encrypt_text);console.log(decrypt_text);输出结果:
I+qwOsXQvBq18KVmX3ainoMHbs3nT+v64s
/upload/image/201602120012.jpg
以上这篇Node.js DES加密的简单实现就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
因项目需要,需要Node.js与PHP做接口调用,发现node.js对中文使用md5加密与php对中文md5加密的结果不同。PHP输出:程序员md5:72d9a
本文实例讲述了Node.js实现批量下载图片简单操作。分享给大家供大家参考,具体如下:使用Node.js批量下载图片首先要获取到图片链接:constimg=["
Node.js是一个开源JavaScript运行时环境。在这里,您将学习如何在CentOS8服务器上安装Node.js。什么是Node.js?Node.js是一
什么是Node.js的模块(Module)?在Node.js中,模块是一个库或框架,也是一个Node.js项目。Node.js项目遵循模块化的架构,当我们创建了
Node.JS是一个控制台程序,如果想要从Node.JS弹出Windows系统提示框的话,有很多方法可以实现。比如借助electron或node-webkit: