nodejs express配置自签名https服务器的方法


Posted in NodeJs onMay 22, 2018

在nodejs中使用express来搭建框架可以说是非常的简单方便,但是一般默认创建的都是http服务器,也就是只能通过http协议进行访问。如今https已经是发展趋势,我们应该顺应时代的潮流。在本篇文章中,我们将会来使用自签名的方式创建证书,然后使用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 express配置自签名https服务器的方法

此时把这三个文件拷贝到你的nodejs项目目录下,比如我直接在项目根目录下新建certificate文件夹,然后放入三个文件:

nodejs express配置自签名https服务器的方法

 完成以上步骤后,修改项目的启动文件,我这里的启动文件是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; 
 
//创建http服务器 
httpServer.listen(PORT, function() { 
  console.log('HTTP Server is running on: http://localhost:%s', PORT); 
}); 
 
//创建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不是系统内置模块,需要通过npm安装):

http访问:

nodejs express配置自签名https服务器的方法

https访问:

nodejs express配置自签名https服务器的方法

可以看到我们已经成功使用https来访问我们的服务器,但是Chrome浏览器却显示红色的Not Secure,这是因为这个证书是我们自建的,没有经过第三方机构验证,所以会出现警告的提示。后续博客我们会介绍如何申请经过认证的证书。

在Chrome浏览器中打开开发者模式,在安全Security页中可以看到当前页面的证书信息,如下所示:

nodejs express配置自签名https服务器的方法     

点击“View certificate”则可以看到证书的详情:

nodejs express配置自签名https服务器的方法

展开detail则可以看到我们创建证书的时候输入的各项证书信息。

同时我们也可以使用Postman来模拟客户端请求(实际开发中,服务端同学可以把证书发给客户端同学,经过简单配置就能实现https通信了):

http请求:

nodejs express配置自签名https服务器的方法

https请求:

nodejs express配置自签名https服务器的方法

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

NodeJs 相关文章推荐
基于NodeJS的前后端分离的思考与实践(三)轻量级的接口配置建模框架
Sep 26 NodeJs
浅谈Nodejs观察者模式
Oct 13 NodeJs
nodejs服务搭建教程 nodejs访问本地站点文件
Apr 07 NodeJs
nodejs接入阿里大鱼短信验证码的方法
Jul 10 NodeJs
详解Nodejs 通过 fs.createWriteStream 保存文件
Oct 10 NodeJs
Mac 安装 nodejs方法(图文详细步骤)
Oct 30 NodeJs
nodejs async异步常用函数总结(推荐)
Nov 17 NodeJs
NodeJS实现视频转码的示例代码
Nov 18 NodeJs
windows系统下更新nodejs版本的方案
Nov 24 NodeJs
nodejs使用http模块发送get与post请求的方法示例
Jan 08 NodeJs
nodejs简单访问及操作mysql数据库的方法示例
Mar 15 NodeJs
nodejs 简单实现动态html的方法
May 12 NodeJs
通过nodejs 服务器读取HTML文件渲染到页面的方法
May 17 #NodeJs
解决nodejs的npm命令无反应的问题
May 17 #NodeJs
Mac下通过brew安装指定版本的nodejs教程
May 17 #NodeJs
对mac下nodejs 更新到最新版本的最新方法(推荐)
May 17 #NodeJs
nodejs前端模板引擎swig入门详解
May 15 #NodeJs
Nodejs 发布自己的npm包并制作成命令行工具的实例讲解
May 15 #NodeJs
Linux Centos7.2下安装nodejs&npm配置全局路径的教程
May 15 #NodeJs
You might like
PHP Session_Regenerate_ID函数双释放内存破坏漏洞
2011/01/27 PHP
php中base64_decode与base64_encode加密解密函数实例
2014/11/24 PHP
php实现的SESSION类
2014/12/02 PHP
PHP二维数组排序简单实现方法
2016/02/14 PHP
JQuery实现的在新窗口打开链接的方法小结
2010/04/22 Javascript
jQuery 锚点跳转滚动条平滑滚动一句话代码
2010/04/30 Javascript
点击显示指定元素隐藏其他同辈元素的方法
2014/02/19 Javascript
javascript结合ajax读取txt文件内容
2014/12/05 Javascript
swtich/if...else的替代语句
2015/08/16 Javascript
javaScript中定义类或对象的五种方式总结
2016/12/04 Javascript
深入nodejs中流(stream)的理解
2017/03/27 NodeJs
vue+vuex+axio从后台获取数据存入vuex实现组件之间共享数据
2017/04/22 Javascript
nodejs之get/post请求的几种方式小结
2017/07/26 NodeJs
vuex与组件联合使用的方法
2018/05/10 Javascript
NodeJs项目中关闭ESLint的方法
2018/08/09 NodeJs
Bootstrap的aria-label和aria-labelledby属性实例详解
2018/11/02 Javascript
Puppeteer 爬取动态生成的网页实战
2018/11/14 Javascript
微信小程序 button样式设置为图片的方法
2020/06/19 Javascript
Jquery 获取相同NAME 或者id删除行操作
2020/08/24 jQuery
python网络编程学习笔记(六):Web客户端访问
2014/06/09 Python
深入了解Python数据类型之列表
2016/06/24 Python
Python的几种主动结束程序方式
2019/11/22 Python
pytorch之ImageFolder使用详解
2020/01/06 Python
django自带的权限管理Permission用法说明
2020/05/13 Python
Python 基于jwt实现认证机制流程解析
2020/06/22 Python
香港时尚女装购物网站:ZAFUL
2017/07/19 全球购物
英国时尚泳装品牌:Maru Swimwear
2019/10/06 全球购物
Fox Racing英国官网:越野摩托车和山地自行车服装
2020/02/26 全球购物
个人现实表现材料
2014/02/04 职场文书
产品售后服务承诺书
2014/05/21 职场文书
交通安全横幅标语
2014/10/07 职场文书
2014年反腐倡廉工作总结
2014/12/05 职场文书
2016年班主任培训心得体会
2016/01/07 职场文书
CSS3 制作精美的定价表
2021/04/06 HTML / CSS
pandas提升计算效率的一些方法汇总
2021/05/30 Python
MySQL的存储过程和相关函数
2022/04/26 MySQL