国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > JavaScript > 正文

nodejs express配置自簽名https服務器的方法

2019-11-19 13:48:02
字體:
來源:轉載
供稿:網友

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

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

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

openssl genrsa 1024 > /pathway/private.pem

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

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

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

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

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

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

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

var express = require('express'); // 項目服務端使用express框架 var app = express(); var path = require('path'); var fs = require('fs');  //使用nodejs自帶的http、https模塊 var http = require('http'); var https = require('https');  //根據項目的路徑導入生成的證書文件 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);  //可以分別設置http、https的訪問端口號 var PORT = 8000; var SSLPORT = 8001;  //創(chuàng)建http服務器 httpServer.listen(PORT, function() {   console.log('HTTP Server is running on: http://localhost:%s', PORT); });  //創(chuàng)建https服務器 httpsServer.listen(SSLPORT, function() {   console.log('HTTPS Server is running on: https://localhost:%s', SSLPORT); });  //可以根據請求判斷是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!');   } }); 

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

http訪問:

https訪問:

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

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

     

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

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

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

http請求:

https請求:

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持武林網。

發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
主站蜘蛛池模板: 鄢陵县| 常州市| 江西省| 雅江县| 靖边县| 上蔡县| 娱乐| 扬中市| 杭州市| 建阳市| 临澧县| 定边县| 城市| 呼伦贝尔市| 清流县| 泾阳县| 曲靖市| 宜兰市| 龙泉市| 临安市| 合川市| 祁阳县| 岱山县| 峨眉山市| 美姑县| 岗巴县| 客服| 大洼县| 闸北区| 揭东县| 特克斯县| 池州市| 海城市| 杭州市| 治多县| 黄冈市| 油尖旺区| 汶上县| 德保县| 洛南县| 蒙山县|