成人午夜视频全免费观看高清-秋霞福利视频一区二区三区-国产精品久久久久电影小说-亚洲不卡区三一区三区一区

Node.js進(jìn)階之核心模塊https入門

模塊概覽

創(chuàng)新互聯(lián)是網(wǎng)站建設(shè)技術(shù)企業(yè),為成都企業(yè)提供專業(yè)的成都做網(wǎng)站、網(wǎng)站建設(shè),網(wǎng)站設(shè)計,網(wǎng)站制作,網(wǎng)站改版等技術(shù)服務(wù)。擁有十年豐富建站經(jīng)驗和眾多成功案例,為您定制適合企業(yè)的網(wǎng)站。十年品質(zhì),值得信賴!

這個模塊的重要性,基本不用強(qiáng)調(diào)了。在網(wǎng)絡(luò)安全問題日益嚴(yán)峻的今天,網(wǎng)站采用HTTPS是個必然的趨勢。

在nodejs中,提供了 https 這個模塊來完成 HTTPS 相關(guān)功能。從官方文檔來看,跟 http 模塊用法非常相似。

本文主要包含兩部分:

  1. 通過客戶端、服務(wù)端的例子,對https模塊進(jìn)行入門講解。
  2. 如何訪問安全證書不受信任的網(wǎng)站。(以 12306 為例子)

篇幅所限,本文無法對 HTTPS協(xié)議 及 相關(guān)技術(shù)體系 做過多講解,有問題歡迎留言交流。

客戶端例子

跟http模塊的用法非常像,只不過請求的地址是https協(xié)議的而已,代碼如下:

var https = require('https');

https.get('https://www.baidu.com', function(res){
  console.log('status code: ' + res.statusCode);
  console.log('headers: ' + res.headers);

  res.on('data', function(data){
    process.stdout.write(data);
  });
}).on('error', function(err){
  console.error(err);
});

服務(wù)端例子

對外提供HTTPS服務(wù),需要有HTTPS證書。如果你已經(jīng)有了HTTPS證書,那么可以跳過證書生成的環(huán)節(jié)。如果沒有,可以參考如下步驟

生成證書

1、創(chuàng)建個目錄存放證書。

mkdir cert
cd cert

2、生成私鑰。

openssl genrsa -out chyingp-key.pem 2048

3、生成證書簽名請求(csr是 Certificate Signing Request的意思)。

openssl req -new \
 -sha256
 -key chyingp-key.key.pem \
 -out chyingp-csr.pem \
 -subj "/C=CN/ST=Guandong/L=Shenzhen/O=YH Inc/CN=www.chyingp.com"

4、生成證書。

openssl x509 \
 -req -in chyingp-csr.pem \
 -signkey chyingp-key.pem \
 -out chyingp-cert.pem

HTTPS服務(wù)端

代碼如下:

var https = require('https');
var fs = require('fs');

var options = {
  key: fs.readFileSync('./cert/chyingp-key.pem'), // 私鑰
  cert: fs.readFileSync('./cert/chyingp-cert.pem') // 證書
};

var server = https.createServer(options, function(req, res){
  res.end('這是來自HTTPS

由于我并沒有 www.chyingp.com 這個域名,于是先配置本地host

127.0.0.1 www.chyingp.com

啟動服務(wù),并在瀏覽器里訪問 http://www.chyingp.com:3000 。注意,瀏覽器會提示你證書不可靠,點擊 信任并繼續(xù)訪問 就行了。

進(jìn)階例子:訪問安全證書不受信任的網(wǎng)站

這里以我們最喜愛的12306最為例子。當(dāng)我們通過瀏覽器,訪問12306的購票頁面 https://kyfw.12306.cn/otn/regist/init 時,chrome會阻止我們訪問,這是因為,12306的證書是自己頒發(fā)的,chrome無法確認(rèn)他的安全性。

對這種情況,可以有如下處理方式:

  1. 停止訪問:著急搶票回家過年的老鄉(xiāng)表示無法接受。
  2. 無視安全警告,繼續(xù)訪問:大部分情況下,瀏覽器是會放行的,不過安全提示還在。
  3. 導(dǎo)入12306的CA根證書:瀏覽器乖乖就范,認(rèn)為訪問是安全的。(實際上還是有安全提示,因為12306用的簽名算法安全級別不夠)

例子:觸發(fā)安全限制

同樣的,通過 node https client 發(fā)起請求,也會遇到同樣問題。我們做下實驗,代碼如下:

var https = require('https');

https.get('https://kyfw.12306.cn/otn/regist/init', function(res){  
  res.on('data', function(data){
    process.stdout.write(data);
  });
}).on('error', function(err){
  console.error(err);
});

運行上面代碼,得到下面的錯誤提示,意思是 安全證書不可靠,拒絕繼續(xù)訪問。

{ Error: self signed certificate in certificate chain
    at Error (native)
    at TLSSocket.<anonymous> (_tls_wrap.js:1055:38)
    at emitNone (events.js:86:13)
    at TLSSocket.emit (events.js:185:7)
    at TLSSocket._finishInit (_tls_wrap.js:580:8)
    at TLSWrap.ssl.onhandshakedone (_tls_wrap.js:412:38) code: 'SELF_SIGNED_CERT_IN_CHAIN' }

ps:個人認(rèn)為這里的錯誤提示有點誤導(dǎo)人,12306網(wǎng)站的證書并不是自簽名的,只是對證書簽名的CA是12306自家的,不在可信列表里而已。自簽名證書,跟自己CA簽名的證書還是不一樣的。

類似在瀏覽器里訪問,我們可以采取如下處理:

  1. 不建議:忽略安全警告,繼續(xù)訪問;
  2. 建議:將12306的CA加入受信列表;

方法1:忽略安全警告,繼續(xù)訪問

非常簡單,將 rejectUnauthorized 設(shè)置為 false 就行,再次運行代碼,就可以愉快的返回頁面了。

// 例子:忽略安全警告
var https = require('https');
var fs = require('fs');

var options = { 
  hostname: 'kyfw.12306.cn',
  path: '/otn/leftTicket/init',
  rejectUnauthorized: false // 忽略安全警告
};

var req = https.get(options, function(res){ 
  res.pipe(process.stdout);  
});

req.on('error', function(err){
  console.error(err.code);
});

方法2:將12306的CA加入受信列表

這里包含3個步驟:

  1. 下載 12306 的CA證書
  2. 將der格式的CA證書,轉(zhuǎn)成pem格式
  3. 修改node https的配置

1、下載 12306 的CA證書

在12306的官網(wǎng)上,提供了CA證書的 下載地址 ,將它保存到本地,命名為 srca.cer。

2、將der格式的CA證書,轉(zhuǎn)成pem格式

https初始化client時,提供了 ca 這個配置項,可以將 12306 的CA證書添加進(jìn)去。當(dāng)你訪問 12306 的網(wǎng)站時,client就會用ca配置項里的 ca 證書,對當(dāng)前的證書進(jìn)行校驗,于是就校驗通過了。

需要注意的是,ca 配置項只支持 pem 格式,而從12306官網(wǎng)下載的是der格式的。需要轉(zhuǎn)換下格式才能用。關(guān)于 pem、der的區(qū)別,可參考 這里 。

openssl x509 -in srca.cer -inform der -outform pem -out srca.cer.pem

3、修改node https的配置

修改后的代碼如下,現(xiàn)在可以愉快的訪問12306了。

// 例子:將12306的CA證書,加入我們的信任列表里
var https = require('https');
var fs = require('fs');
var ca = fs.readFileSync('./srca.cer.pem');

var options = { 
 hostname: 'kyfw.12306.cn',
 path: '/otn/leftTicket/init',
 ca: [ ca ]
};

var req = https.get(options, function(res){ 
 res.pipe(process.stdout); 
});

req.on('error', function(err){
 console.error(err.code);
});

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持創(chuàng)新互聯(lián)。

文章題目:Node.js進(jìn)階之核心模塊https入門
當(dāng)前地址:http://jinyejixie.com/article0/ggesoo.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供外貿(mào)建站、網(wǎng)站導(dǎo)航、動態(tài)網(wǎng)站、網(wǎng)站收錄移動網(wǎng)站建設(shè)、網(wǎng)站內(nèi)鏈

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)

綿陽服務(wù)器托管
长丰县| SHOW| 怀仁县| 长丰县| 寿光市| 盐亭县| 宜良县| 监利县| 东莞市| 海盐县| 长阳| 曲周县| 新余市| 巴彦淖尔市| 清镇市| 潮安县| 琼结县| 遵义县| 凤山市| 密山市| 大厂| 垣曲县| 北海市| 太原市| 兴化市| 东宁县| 高要市| 夏邑县| 精河县| 延吉市| 安岳县| 砚山县| 剑川县| 大埔县| 辉县市| 新兴县| 鹤壁市| 芦溪县| 麦盖提县| 广平县| 宁南县|