Node搭建https服務(wù)器實(shí)例詳解
本文旨在分享搭建https服務(wù)器的過程,具體知識(shí)點(diǎn)以及相關(guān)概念請(qǐng)自行查詢。
第一步:創(chuàng)建文件目錄如下,在index中引用外部的script.js文件,server.js是服務(wù)器文件。
第二步:創(chuàng)建自己的CA機(jī)構(gòu).
在根文件夾下打開命令行工具,直接依次使用下面的命令。
//為CA生成私鑰 openssl genrsa -out ca-key.pem -des 1024 //通過CA私鑰生成CSR openssl req -new -key ca-key.pem -out ca-csr.pem //通過CSR文件和私鑰生成CA證書 openssl x509 -req -in ca-csr.pem -signkey ca-key.pem -out ca-cert.pem
注意下面的運(yùn)行結(jié)果:enter pass phrase for ca-key.pem:設(shè)置自己的密碼,要記住,接下來(lái)的操作中要多次驗(yàn)證??蛻舳撕头?wù)端的代碼中要用,這里我設(shè)置的是sun13083691283.
需要設(shè)置項(xiàng)均可以直接enter鍵默認(rèn)跳過。
第三步:創(chuàng)建服務(wù)器端證書
//(1)為服務(wù)器生成私鑰 openssl genrsa -out server-key.pem 1024 //(2)利用服務(wù)器私鑰文件服務(wù)器生成CSR openssl req -new -key server-key.pem -config openssl.cnf -out server-csr.pem
這一步可能會(huì)報(bào)錯(cuò),Unable to load config info from /user/local/ssl/openssl.cnf,或者有關(guān)openssl.cnf的錯(cuò)誤,在根目錄下創(chuàng)建一
個(gè)openssl.cnf的文件,將下面的代碼拷貝進(jìn)去。
[req] distinguished_name = req_distinguished_name req_extensions = v3_req [req_distinguished_name] countryName = Country Name (2 letter code) countryName_default = CN stateOrProvinceName = State or Province Name (full name) stateOrProvinceName_default = BeiJing localityName = Locality Name (eg, city) localityName_default = YaYunCun organizationalUnitName = Organizational Unit Name (eg, section) organizationalUnitName_default = Domain Control Validated commonName = Internet Widgits Ltd commonName_max = 64 [ v3_req ] # Extensions to add to a certificate request basicConstraints = CA:FALSE keyUsage = nonRepudiation, digitalSignature, keyEncipherment subjectAltName = @alt_names [alt_names] #注意這個(gè)IP.1的設(shè)置,IP地址需要和你的服務(wù)器的監(jiān)聽地址一樣 IP.1 = 127.0.0.1
//(3)通過服務(wù)器私鑰文件和CSR文件生成服務(wù)器證書 openssl x509 -req -CA ca-cert.pem -CAkey ca-key.pem -CAcreateserial -in server-csr.pem -out server-cert.pem -extensions v3_req -extfile openssl.cnf
第四步:創(chuàng)建客戶端證書
//(1)生成客戶端私鑰 openssl genrsa -out client-key.pem //(2)利用私鑰生成CSR openssl req -new -key client-key.pem -out client-csr.pem //(3)生成客戶端證書 openssl x509 -req -CA ca-cert.pem -CAkey ca-key.pem -CAcreateserial -in client-csr.pem -out client-cert.pem
第五步:將證書打包
//(1)打包服務(wù)器端證書 openssl pkcs12 -export -in server-cert.pem -inkey server-key.pem -certfile ca-cert.pem -out server.pfx //(2)打包客戶端證書 openssl pkcs12 -export -in client-cert.pem -inkey client-key.pem -certfile ca-cert.pem -out client.pfx
打包結(jié)束后在文件夾下會(huì)看到如下文件,將其放到keys文件中。
第六步:編寫服務(wù)端代碼
注意:代碼里面的passphrase要填寫之前設(shè)置的密碼,sun13083691283
var https = require('https'); var fs = require('fs'); var options = { pfx:fs.readFileSync('./keys/server.pfx','utf-8'), passphrase:'your password' }; https.createServer(options,function(req,res){ res.writeHead(200); res.end('hello world\n'); }).listen(3000,'127.0.0.1');
第七步:編寫客戶端代碼
注意:代碼里面的passphrase要填寫之前設(shè)置的密碼,sun13083691283
var https = require('https'); var fs = require('fs'); var options = { hostname:'127.0.0.1', port:3000, path:'/', method:'GET', pfx:fs.readFileSync('./keys/server.pfx','utf-8'), passphrase:'your password', agent:false }; options.agent = new https.Agent(options); var req = https.request(options,function(res){ console.log("statusCode: ", res.statusCode); console.log("headers: ", res.headers); res.setEncoding('utf-8'); res.on('data',function(d){ console.log(d); }) }); req.end(); req.on('error',function(e){ console.log(e); })
第八步:打開瀏覽器驗(yàn)證
參考資料:https://cnodejs.org/topic/54745ac22804a0997d38b32d
PS:這里需要注意一點(diǎn),筆者在測(cè)試的時(shí)候,由于node.js相關(guān)模塊的版本問題,調(diào)用 fs.readFileSync
函數(shù)需要指明編碼類型,否則返回Buffer結(jié)果,并在運(yùn)行時(shí)報(bào)錯(cuò)!這種報(bào)錯(cuò)在很多類似的網(wǎng)絡(luò)資料上都會(huì)遇到。
相關(guān)文章
Nodejs+Socket.io實(shí)現(xiàn)通訊實(shí)例代碼
本篇文章主要介紹了Nodejs+Socket.io實(shí)現(xiàn)通訊實(shí)例代碼,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來(lái)看看吧2017-02-02Nodejs中使用puppeteer控制瀏覽器中視頻播放功能
本項(xiàng)目主要功能為在瀏覽器中自動(dòng)播放視頻,并且實(shí)現(xiàn)音量控制,快進(jìn)快退,全屏控制,播放暫??刂频裙δ堋?duì)Nodejs中使用puppeteer控制瀏覽器中視頻播放功能感興趣的朋友跟隨小編一起看看吧2019-08-08nodejs轉(zhuǎn)換音頻文件格式并壓縮導(dǎo)出zip格式(vscode語(yǔ)音插件開發(fā))
FFmpeg是一套開源的音視頻處理工具,通俗地講,可以對(duì)音視頻文件進(jìn)行剪切、拼接、水印、轉(zhuǎn)碼等處理,這篇文章主要介紹了nodejs轉(zhuǎn)換音頻文件格式并壓縮導(dǎo)出zip格式(vscode語(yǔ)音插件開發(fā)),需要的朋友可以參考下2023-05-05Node.js實(shí)現(xiàn)登陸注冊(cè)功能
這篇文章主要為大家詳細(xì)介紹了Node.js實(shí)現(xiàn)登陸注冊(cè)功能,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-08-08node.js通過axios實(shí)現(xiàn)網(wǎng)絡(luò)請(qǐng)求的方法
下面小編就為大家分享一篇node.js通過axios實(shí)現(xiàn)網(wǎng)絡(luò)請(qǐng)求的方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來(lái)看看吧2018-03-03基于node+websocket+html實(shí)現(xiàn)騰訊課堂聊天室聊天功能
這篇文章主要介紹了基于node+websocket+html實(shí)現(xiàn)騰訊課堂聊天室聊天功能,本文通過截圖實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的工作或?qū)W習(xí)具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-03-03