Node.js v0.10.31API手冊-加密

Node.js v0.10.31API手冊-文件夹

加密(Crypto)

使用 require(‘crypto‘) 来调用该模块。

crypto模块提供在HTTPS或HTTP连接中封装安全凭证的方法。

它提供OpenSSL中的一系列哈希方法,包含hmac、cipher、decipher、签名和验证等方法的封装。

crypto.getCiphers()

返回一个数组,包括支持的加密算法的名字。

演示样例:

var ciphers = crypto.getCiphers();
console.log(ciphers); // [‘AES-128-CBC‘, ‘AES-128-CBC-HMAC-SHA1‘, ...]

crypto.getHashes()

返回一个包括所支持的哈希算法的数组。

演示样例:

var hashes = crypto.getHashes();
console.log(hashes); // [‘sha‘, ‘sha1‘, ‘sha1WithRSAEncryption‘, ...]

crypto.createCredentials(details)

创建一个加密凭证对象。接受一个可选的參数对象:

  • pfx : 一个字符串或者buffer对象。代表经PFX或者PKCS12编码产生的私钥、证书以及CA证书
  • key : 一个字符串,代表经PEM编码产生的私钥
  • passphrase : 私钥或者pfx的password
  • cert : 一个字符串。代表经PEM编码产生的证书
  • ca : 一个字符串或者字符串数组,表示可信任的经PEM编码产生的CA证书列表
  • crl : 一个字符串或者字符串数组。表示经PEM编码产生的CRL(证书吊销列表 Certificate Revocation List)
  • ciphers: 一个字符串,表示须要使用或者排除的加密算法 能够在http://www.openssl.org/docs/apps/ciphers.html#CIPHER_LIST_FORMAT 查看很多其它关于加密算法格式的资料。

假设没有指定ca。node.js会使用http://mxr.mozilla.org/mozilla/source/security/nss/lib/ckfw/builtins/certdata.txt提供的公共可信任的CA列表。

crypto.createHash(algorithm)

创建并返回一个哈希对象,一个使用所给算法的用于生成摘要的加密哈希。

algorithm 取决与平台上所安装的
OpenSSL 版本号所支持的算法。比方‘sha1‘‘md5‘‘sha256‘‘sha512‘ 等等。在近期的发行版本号中。openssl
list-message-digest-algorithms
 会显示可用的摘要算法。

演示样例:这段程序会计算出一个文件的
sha1 摘要值。

var filename = process.argv[2];
var crypto = require(‘crypto‘);
var fs = require(‘fs‘);

var shasum = crypto.createHash(‘sha1‘);

var s = fs.ReadStream(filename);
s.on(‘data‘, function(d) {
  shasum.update(d);
});

s.on(‘end‘, function() {
  var d = shasum.digest(‘hex‘);
  console.log(d +
时间: 2024-08-05 19:34:18

Node.js v0.10.31API手冊-加密的相关文章

Node.js v0.10.31API手册-Domain

Node.js v0.10.31API手册-目录 Domain(域) Domains 提供了一种方式,即以一个单一的组的形式来处理多个不同的IO操作.如果任何一个注册到domain的事件触发器或回调触发了一个'error'事件,或者抛出一个错误,那么domain对象将会被通知到.而不是直接让这个错误的上下文从`process.on('uncaughtException')'处理程序中丢失掉,也不会致使程序因为这个错误伴随着错误码立即退出. 警告: 不要忽视错误! Domain error处理程序

Node.js v0.10.31API手册-事件

Node.js v0.10.31API手册-目录 Events(事件) Node里面的许多对象都会分发事件:一个net.Server对象会在每次有新连接时分发一个事件, 一个fs.readStream对象会在文件被打开的时候发出一个事件. 所有这些产生事件的对象都是events.EventEmitter的实例. 你可以通过require("events")来访问该模块. 通常,事件名是驼峰命名 (camel-cased) 的字符串.不过也没有强制的要求,任何字符串都是可以使用的. 为了

Node.js v0.10.31API手册-DNS

原API变化,故译文与之前译文样式上有所不同 Node.js v0.10.31API手册-目录 DNS 使用 require('dns') 引入此模块.dns 模块中的所有方法都使用了 C-Ares,除了 dns.lookup 使用了线程池中的 getaddrinfo(3).C-Ares 比 getaddrinfo 要快得多,但系统解析器相对于其它程序的操作要更固定.当一个用户使用 net.connect(80, 'google.com') 或 http.get({ host: 'google.

Node.js v0.10.31API手册-目录

这段时间,想找些新的技术学习学习,看上了Node.js,万丈高楼平地起,这就从它的API开始,然后就顺便翻译一下. Node.js v0.10.31API手册-简介 Node.js v0.10.31API手册-断言 Node.js v0.10.31API手册-Buffer Node.js v0.10.31API手册-Addons插件 持续更新中...

Node.js v0.10.31API手册-加密

加密(Crypto) 使用 require('crypto') 来调用该模块. crypto模块提供在HTTPS或HTTP连接中封装安全凭证的方法. 它提供OpenSSL中的一系列哈希方法,包括hmac.cipher.decipher.签名和验证等方法的封装. crypto.getCiphers() 返回一个数组,包含支持的加密算法的名字. 示例: var ciphers = crypto.getCiphers(); console.log(ciphers); // ['AES-128-CBC'

Node.js v0.10.31API手册-集群

集群 单个 Node 实例运行在单个线程中.要发挥多核系统的能力,用户有时候需要启动一个 Node 进程集群来处理负载. 集群模块允许你方便地创建一个共享服务器端口的进程网络. var cluster = require('cluster'); var http = require('http'); var numCPUs = require('os').cpus().length; if (cluster.isMaster) { // Fork workers. for (var i = 0;

Node.js v0.10.31API手册-子进程

子进程 Node 通过 child_process 模块提供了类似 popen(3) 的处理三向数据流(stdin/stdout/stderr)的功能. 它能够以完全非阻塞的方式与子进程的 stdin.stdout 和 stderr 以流式传递数据.(请注意,某些程序在内部使用行缓冲 I/O.这不会影响到 node.js,但您发送到子进程的数据不会被立即消费.) 使用 require('child_process').spawn()或者 require('child_process').fork

Node.js v0.10.31API手册-Addons插件

Addons Addons插件就是动态连接库.Addons插件将Node与C库和C++库链接起来.它的API(目前来说)相当复杂,涉及到了几个类库的知识. V8 JavaScript引擎是一个 C++ 类库..用于和JavaScript进行交互的接口.创建对象, 调用函数等. 文档大部分在这里:v8.h 头文件 (deps/v8/include/v8.h在Node源代码目录里), 也有可用的线上文档线上. libuv, C语言编写的事件循环类库.任何时候需要等待一个文件描述符变为可读状态,等待一

Node.js v0.10.31API手册-控制台

控制台 Object 用于向 stdout 和 stderr 打印字符.类似于大部分 Web 浏览器提供的 console 对象函数,在这里则是输出到 stdout 或 stderr. 当输出目标是一个终端或者文件时,console函数是同步的(为了防止过早退出时丢失信息).当输出目标是一个管道时它们是异步的(防止阻塞过长时间). 也就是说,在下面的例子中,stdout 是非阻塞的,而 stderr 则是阻塞的. $ node script.js 2> error.log | tee info.