欧美一区二区三区老妇人-欧美做爰猛烈大尺度电-99久久夜色精品国产亚洲a-亚洲福利视频一区二区

nodejsexpress配置自簽名https服務(wù)器的方法

在nodejs中使用express來搭建框架可以說是非常的簡單方便,但是一般默認創(chuàng)建的都是http服務(wù)器,也就是只能通過http協(xié)議進行訪問。如今https已經(jīng)是發(fā)展趨勢,我們應(yīng)該順應(yīng)時代的潮流。在本篇文章中,我們將會來使用自簽名的方式創(chuàng)建證書,然后使用express框架來搭建https服務(wù)器,最后讓瀏覽器或者客戶端使用https協(xié)議進行訪問。

公司主營業(yè)務(wù):成都網(wǎng)站制作、網(wǎng)站設(shè)計、移動網(wǎng)站開發(fā)等業(yè)務(wù)。幫助企業(yè)客戶真正實現(xiàn)互聯(lián)網(wǎng)宣傳,提高企業(yè)的競爭能力。成都創(chuàng)新互聯(lián)是一支青春激揚、勤奮敬業(yè)、活力青春激揚、勤奮敬業(yè)、活力澎湃、和諧高效的團隊。公司秉承以“開放、自由、嚴謹、自律”為核心的企業(yè)文化,感謝他們對我們的高要求,感謝他們從不同領(lǐng)域給我們帶來的挑戰(zhàn),讓我們激情的團隊有機會用頭腦與智慧不斷的給客戶帶來驚喜。成都創(chuàng)新互聯(lián)推出建昌免費做網(wǎng)站回饋大家。

首先我們要生成證書文件:

(1)生成私鑰key文件(下面的pathway表示你要保存的文件路徑位置)
 

openssl genrsa 1024 > /pathway/private.pem

(2)通過上面生成的私鑰文件生成CSR證書簽名

 openssl req -new -key /pathway/private.pem -out csr.pem 

(3)通過上述私鑰文件和CSR證書簽名生成證書文件

復(fù)制代碼 代碼如下:
openssl x509 -req -days 365 -in csr.pem -signkey /pathway/private.pem -out /pathway/file.crt
 

此時生成的三個文件如下:

nodejs express配置自簽名https服務(wù)器的方法

此時把這三個文件拷貝到你的nodejs項目目錄下,比如我直接在項目根目錄下新建certificate文件夾,然后放入三個文件:

nodejs express配置自簽名https服務(wù)器的方法

 完成以上步驟后,修改項目的啟動文件,我這里的啟動文件是app.js,或者有人是server.js,以下代碼實現(xiàn)都一樣:

var express = require('express'); // 項目服務(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ù)項目的路徑導入生成的證書文件 
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的訪問端口號 
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ù)請求判斷是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!'); 
  } 
}); 

代碼實現(xiàn)完成后,啟動app.js腳本,可以使用"node app.js"命令來啟動,或者在其他IDE中run, 然后在瀏覽器中訪問(注意express不是系統(tǒng)內(nèi)置模塊,需要通過npm安裝):

http訪問:

nodejs express配置自簽名https服務(wù)器的方法

https訪問:

nodejs express配置自簽名https服務(wù)器的方法

可以看到我們已經(jīng)成功使用https來訪問我們的服務(wù)器,但是Chrome瀏覽器卻顯示紅色的Not Secure,這是因為這個證書是我們自建的,沒有經(jīng)過第三方機構(gòu)驗證,所以會出現(xiàn)警告的提示。后續(xù)博客我們會介紹如何申請經(jīng)過認證的證書。

在Chrome瀏覽器中打開開發(fā)者模式,在安全Security頁中可以看到當前頁面的證書信息,如下所示:

nodejs express配置自簽名https服務(wù)器的方法     

點擊“View certificate”則可以看到證書的詳情:

nodejs express配置自簽名https服務(wù)器的方法

展開detail則可以看到我們創(chuàng)建證書的時候輸入的各項證書信息。

同時我們也可以使用Postman來模擬客戶端請求(實際開發(fā)中,服務(wù)端同學可以把證書發(fā)給客戶端同學,經(jīng)過簡單配置就能實現(xiàn)https通信了):

http請求:

nodejs express配置自簽名https服務(wù)器的方法

https請求:

nodejs express配置自簽名https服務(wù)器的方法

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

新聞名稱:nodejsexpress配置自簽名https服務(wù)器的方法
鏈接URL:http://chinadenli.net/article44/jiijee.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供關(guān)鍵詞優(yōu)化搜索引擎優(yōu)化、ChatGPT用戶體驗、軟件開發(fā)網(wǎng)站建設(shè)

廣告

聲明:本網(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ǎng)站建設(shè)