nodejs express配置自簽名https服務(wù)器的方法
在nodejs中使用express來(lái)搭建框架可以說(shuō)是非常的簡(jiǎn)單方便,但是一般默認(rèn)創(chuàng)建的都是http服務(wù)器,也就是只能通過http協(xié)議進(jìn)行訪問。如今https已經(jīng)是發(fā)展趨勢(shì),我們應(yīng)該順應(yīng)時(shí)代的潮流。在本篇文章中,我們將會(huì)來(lái)使用自簽名的方式創(chuàng)建證書,然后使用express框架來(lái)搭建https服務(wù)器,最后讓瀏覽器或者客戶端使用https協(xié)議進(jìn)行訪問。
首先我們要生成證書文件:
(1)生成私鑰key文件(下面的pathway表示你要保存的文件路徑位置)
openssl genrsa 1024 > /pathway/private.pem
(2)通過上面生成的私鑰文件生成CSR證書簽名
openssl req -new -key /pathway/private.pem -out csr.pem
(3)通過上述私鑰文件和CSR證書簽名生成證書文件
此時(shí)生成的三個(gè)文件如下:

此時(shí)把這三個(gè)文件拷貝到你的nodejs項(xiàng)目目錄下,比如我直接在項(xiàng)目根目錄下新建certificate文件夾,然后放入三個(gè)文件:

完成以上步驟后,修改項(xiàng)目的啟動(dòng)文件,我這里的啟動(dòng)文件是app.js,或者有人是server.js,以下代碼實(shí)現(xiàn)都一樣:
var express = require('express'); // 項(xiàng)目服務(wù)端使用express框架
var app = express();
var path = require('path');
var fs = require('fs');
//使用nodejs自帶的http、https模塊
var http = require('http');
var https = require('https');
//根據(jù)項(xiàng)目的路徑導(dǎo)入生成的證書文件
var privateKey = fs.readFileSync(path.join(__dirname, './certificate/private.pem'), 'utf8');
var certificate = fs.readFileSync(path.join(__dirname, './certificate/file.crt'), 'utf8');
var credentials = {key: privateKey, cert: certificate};
var httpServer = http.createServer(app);
var httpsServer = https.createServer(credentials, app);
//可以分別設(shè)置http、https的訪問端口號(hào)
var PORT = 8000;
var SSLPORT = 8001;
//創(chuàng)建http服務(wù)器
httpServer.listen(PORT, function() {
console.log('HTTP Server is running on: http://localhost:%s', PORT);
});
//創(chuàng)建https服務(wù)器
httpsServer.listen(SSLPORT, function() {
console.log('HTTPS Server is running on: https://localhost:%s', SSLPORT);
});
//可以根據(jù)請(qǐng)求判斷是http還是https
app.get('/', function (req, res) {
if(req.protocol === 'https') {
res.status(200).send('This is https visit!');
}
else {
res.status(200).send('This is http visit!');
}
});
代碼實(shí)現(xiàn)完成后,啟動(dòng)app.js腳本,可以使用"node app.js"命令來(lái)啟動(dòng),或者在其他IDE中run, 然后在瀏覽器中訪問(注意express不是系統(tǒng)內(nèi)置模塊,需要通過npm安裝):
http訪問:

https訪問:

可以看到我們已經(jīng)成功使用https來(lái)訪問我們的服務(wù)器,但是Chrome瀏覽器卻顯示紅色的Not Secure,這是因?yàn)檫@個(gè)證書是我們自建的,沒有經(jīng)過第三方機(jī)構(gòu)驗(yàn)證,所以會(huì)出現(xiàn)警告的提示。后續(xù)博客我們會(huì)介紹如何申請(qǐng)經(jīng)過認(rèn)證的證書。
在Chrome瀏覽器中打開開發(fā)者模式,在安全Security頁(yè)中可以看到當(dāng)前頁(yè)面的證書信息,如下所示:
點(diǎn)擊“View certificate”則可以看到證書的詳情:

展開detail則可以看到我們創(chuàng)建證書的時(shí)候輸入的各項(xiàng)證書信息。
同時(shí)我們也可以使用Postman來(lái)模擬客戶端請(qǐng)求(實(shí)際開發(fā)中,服務(wù)端同學(xué)可以把證書發(fā)給客戶端同學(xué),經(jīng)過簡(jiǎn)單配置就能實(shí)現(xiàn)https通信了):
http請(qǐng)求:

https請(qǐng)求:

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
使用node.js對(duì)音視頻文件加密的實(shí)例代碼
本文通過實(shí)例代碼給大家介紹了使用node.js對(duì)音視頻文件加密的方法,非常不錯(cuò),具有參考借鑒價(jià)值,需要的的朋友參考下吧2017-08-08
nodejs操作mongodb的填刪改查模塊的制作及引入實(shí)例
下面小編就為大家分享一篇nodejs操作mongodb的填刪改查模塊的制作及引入實(shí)例,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來(lái)看看吧2018-01-01
詳解webpack打包nodejs項(xiàng)目(前端代碼)
這篇文章主要介紹了webpack打包nodejs項(xiàng)目(前端代碼),小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來(lái)看看吧2018-09-09
node.js項(xiàng)目如何創(chuàng)建websocket模塊
這篇文章主要介紹了node.js項(xiàng)目如何創(chuàng)建websocket模塊問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2024-09-09
Node.js版本發(fā)布策略頻率與穩(wěn)定性的平衡
這篇文章主要為大家介紹了Node.js版本發(fā)布策略頻率與穩(wěn)定性的平衡,幫助大家大家更清晰了解node發(fā)展史,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-10-10
nodejs實(shí)現(xiàn)bigpipe異步加載頁(yè)面方案
本文給大家分享的是使用nodejs結(jié)合bigpipe實(shí)現(xiàn)異步加載頁(yè)面的方案,非常的實(shí)用,也是以后前端性能優(yōu)化的一個(gè)方向,希望大家能夠喜歡。2016-01-01

