在 Express 中将 ReactJS 生产构建部署为 HTTPS

Posted

技术标签:

【中文标题】在 Express 中将 ReactJS 生产构建部署为 HTTPS【英文标题】:Deploying ReactJS production build in Express as HTTPS 【发布时间】:2018-11-09 16:13:23 【问题描述】:

所以我在将我的 React 应用程序部署到生产服务器时是成功的。我正在使用 Express 进行部署。这是我的代码。

const express = require('express')
const path = require('path')
const port = process.env.PORT || 80
const app = express()

app.use(express.static(__dirname + '/build'))

app.get('*', function (request, response)
  response.sendFile(path.resolve(__dirname, 'build', 'index.html'))
)

app.listen(port)

我会将 CertBot 用于 SSL 证书并将其部署为 HTTPS 服务器。我真的不知道如何解决这个问题。

【问题讨论】:

Enabling HTTPS on express.js的可能重复 【参考方案1】:

假设 CertBot 生成 SSL 证书和 SSL 证书密钥到以下位置:

/etc/letsencrypt/live/example.org/fullchain.pem /etc/letsencrypt/live/example.org/privkey.pem

生成证书和密钥后,您需要直接使用https 模块。

您首先需要导出您的 Express 应用:

const express = require('express')
const path = require('path')
const port = process.env.PORT || 80
const app = express()

app.use(express.static(__dirname + '/build'))

app.get('*', function (request, response)
  response.sendFile(path.resolve(__dirname, 'build', 'index.html'))
)

module.export = app

然后只需导入您的 Express 应用并将其与 https 模块挂钩:

const https = require('https');
const fs = require('fs');
const app = require('./app.js');

const server = https.createServer(
  key: fs.readFileSync('/etc/letsencrypt/live/example.org/fullchain.pem', 'utf8'),
  cert: fs.readFileSync('/etc/letsencrypt/live/example.org/privkey.pem', 'utf8')
, app);

server.listen(3000);

请注意这基本上是 ./bin/www 为您所做的,但我已将其调整为使用 https 而不是 http 模块。

见What does "./bin/www" do in Express 4.x?

【讨论】:

tls_common.js:88 c.context.setCert(options.cert); - 这是我得到的错误。 ˇ

以上是关于在 Express 中将 ReactJS 生产构建部署为 HTTPS的主要内容,如果未能解决你的问题,请参考以下文章

对本地主机的调用不适用于 ReactJS/Axios/Express

reactjs:提供到公共文件夹的文件在生产构建中解析为 404 错误,但在开发中使用 npm start

使用 Passport 的 Express 服务器、ReactJS 和 Relay 应用程序的身份验证策略

如何为 electron + react js + next 进行生产构建

如何通过 REST API 微服务(使用 Express 构建)将 MongoDB 更改流与节点 js 一起使用

React 生产构建 Express 侦听器或服务器未运行