MD5:消息摘要算法(Message-Digest Algorithm)

SHA家族:安全散列算法( Secure Hash Algorithm )

1.首先看一个简单的加密

"use strict";
//引入crypto模块
const crypto = require("crypto");
//创建一个使用md5加密的hash对象,也可以使用sha1、sha256、sha512加密
const hash = crypto.createHash("md5");
//添加需要加密的内容,update方法可以有多个
hash.update("这是要加密的内容。");
hash.update("This is what needs to be encrypted.");
//将使用update进行加密的内容用十六进制的方式打印出来,也可以传入latin1、base64
console.log( hash.digest("hex") );
//需要注意的是digest只能出现一次

注:

a.这里的加密使用的是 update 和 digest 方法

b.update方法可以出现多次,而且必须出现在digest方法前面

c.digest方法只能出现一次

d.使用上述这种方法每次需要加密的时候只能加密一段

2.接下来我们看一下怎么实现将一整个文件进行加密( 本质上就是使用流对文件进行加密 )

"use strict"

const crypto = require( "crypto" );

const fs = require( "fs" );

let hash = crypto.createHash( "sha512" );

//创建阅读流,将test.txt文本使用hash对象加密后输出到控制台
fs.createReadStream( "test.txt" ).pipe( hash ).pipe( process.stdout );

( 关于流模块的介绍 )

关于流的pipe方法的使用 )

3.使用Hash对象进行加密( 与方法1类似,区别是该方法需要一个readable事件 )

"use strict";

const crypto = require("crypto");
const hash = crypto.createHash("sha256");

//加密已经完成的时候执行,判断加密是否完成的标准是end方法是否执行
hash.on("readable", () => {
  //读取已经经过hash加密的内容
  let data = hash.read();
  if(data){
    console.log(data.toString("base64"));
  }
});

//需要进行加密的内容
hash.write("Some Text!");

//告诉系统加密已经完成
hash.end();

注:

1.write 方法和 end 方法可以有多个

2.end 方法必须在 write 方法之后

3.只有调用了 end 方法 监听事件 readable 才能执行

4.使用 read 方法来查看加密的内容

5.需要在 readable 事件中加data判断,否则会报错( TypeError: Cannot read property 'toString' of null )

Node.js 内置模块crypto加密模块(1) MD5 和 SHA的更多相关文章

  1. Node.js 内置模块crypto加密模块(4) Diffie Hellman

    Diffie-Hellman( DH ):密钥交换协议/算法 ( Diffie-Hellman Key Exchange/Agreement Algorithm ) 百科摘录: Diffie-Hell ...

  2. Node.js 内置模块crypto加密模块(3) HMAC

    HMAC:哈希消息认证码 ( Hash-based Message Authentication Code ) HMAC是密钥相关的哈希算法 使用 HMAC 进行加密的Node实现的一种方法: &qu ...

  3. Node.js 内置模块crypto加密模块(5) RSA

    RSA加密算法 写在前面: 了解RSA算法的原理请查看下面的文章 一文搞懂 RSA 算法 来源:简书  作者:somenzz 在使用 Node 进行 RSA 加密之前我们首先需要获取RSA公共和私有密 ...

  4. Node.js 内置模块crypto加密模块(2) AES

    AES:高级加密标准 ( Advanced Encryption Standard ) AES是一种对称加密算法:加密需要密钥,且加密密钥和解密密钥相同 下面是AES加密的Node实现: " ...

  5. Node.js 内置模块crypto使用事件方法(onreadable)加密的一些问题

    javaScript代码如下: 'use strict'; const crypto = require('crypto'); //实例化一个AES加密对象 const aesEncrept = cr ...

  6. [Node.js] Gzip + crypto in stream

    We can using gzip and crypto with stream: const fs = require('fs') const zlib = require('zlib') cons ...

  7. Node.js 内置模块fs(文件系统)

    fs模块的三个常用方法 1.fs.readFile() -- 读文件 2.fs.writeFile() -- 写文件 3.fa.stat() -- 查看文件信息 fs模块不同于其它模块的地方是它有异步 ...

  8. Node.js 内置模块fs的readdir方法 查看某个文件夹里面包含的文件内容

    fs.readdir(path[, options], callback) 例: "use strict"; const fs = require("fs"); ...

  9. Node.js 内置模块Stream(流)

    "流"是一种抽象的数据结构 通过使用"流"可以将一段数据分割成几段,并按顺序传输,使用"流"可以降低对系统性能的要求,减少对CPU的消耗 S ...

随机推荐

  1. Zookeeper四字命令

    ZooKeeper 支持某些特定的四字命令(The Four Letter Words)与其进行交互.它们大多是查询命令,用来获取 ZooKeeper 服务的当前状态及相关信息.用户在客户端可以通过 ...

  2. Linux-3.14.12内存管理笔记【kmalloc与kfree实现】【转】

    本文转载自:http://blog.chinaunix.net/uid-26859697-id-5573776.html kmalloc()是基于slab/slob/slub分配分配算法上实现的,不少 ...

  3. 如何用命令行删除EasyBCD开机选择项?

    用硬盘安装Ubuntu方法的windows双系统电脑上面,很多人都是用EasyBCD设置的开机启动选择.所以当我们不需要双系统的时候,或者已经删除双系统后,或者安装双系统失败的情况下,发现电脑的开机启 ...

  4. js正则表达式(2)

    找到以某个字符串开头的字符串 var myReg=/^(abc)/gim; 如果不加m,那么只找一行,而加了m可以找到每行中以该字符串开头的匹配文本. 如: abcsfsdfasd7890hklfah ...

  5. html5--1.19 通用属性

    html5--1.19 通用属性 学习要点: 1.通用属性的概念及几个常用的通用属性2.对属性值的若干点补充 通用属性 通用属性(全局属性)可以用于任何的HTML5元素:通用属性有十几种:这节课不会全 ...

  6. Linux网络编程 gethostbyaddr()

    C语言函数 概述: 返回对应于给定地址的主机信息. #include <winsock.h> struct hostent FAR *PASCAL FAR gethostbyaddr(co ...

  7. 一:AMQP协议标准简单介绍

    一:AMQP协议?--->AMQP 是 Advanced Message Queuing Protocol,即高级消息队列协议.和前面罗列的技术不同,AMQP 是一个标准化的消息中间件协议--- ...

  8. 主备角色switch

    理论知识:Switchover 切换允许primary 和一个备库进行切换,并且这种切换没有数据丢失. 前提条件: 1) 主备库相关参数 fal_client.fal_server .standby_ ...

  9. wpf datagrid row的命中测试

    1. 添加鼠标左键处理 AddHandler(DataGrid.MouseLeftButtonDownEvent, new RoutedEventHandler(grdStudyList_MouseL ...

  10. Lagom学习(一)

    Lagom是JAVA系下响应式 微服务框架,其特性包括: 目前,大多数已有的微服务框架关注于简化单个微服务的构建,Lagom将其扩展到了微服务所构成的系统,分布式系统的复杂性. 同步通信使用HTTP, ...