【发布时间】:2019-08-13 16:55:23
【问题描述】:
系统信息
目标
在本地主机上使用 SSL over HTTPS 为 Web 应用程序提供服务
做了什么
- 使用Create Next App 创建了基本的 NextJS 应用程序
- 使用 OpenSSL 生成证书和密钥并将其移动到项目目录中
- 添加了 Express 依赖项
- 将应用配置为在
server.js中使用 express - 将脚本更改为在
package.json脚本中使用server.js。
server.js
const express = require('express');
const next = require('next');
const dev = process.env.NODE_ENV !== 'production';
const app = next({ dev });
const handle = app.getRequestHandler();
const port = 3000;
const https = require('https');
const fs = require('fs');
const httpsOptions = {
key: fs.readFileSync('./certificates/key.pem'),
cert: fs.readFileSync('./certificates/cert.pem')
};
app
.prepare()
.then(() => {
const server = express();
server.get('*', (req, res) => {
return handle(req, res);
});
server.listen(port, err => {
if (err) throw err;
console.log('> Ready on http://localhost: ' + port);
});
})
.catch(ex => {
console.error(ex.stack);
process.exit(1);
});
额外信息
应用程序当前在使用yarn dev 初始化时可以运行。我曾尝试使用 this answer 通过 https 为应用程序提供服务,但我无法弄清楚如何使用 NextJS 将其应用于我当前的设置。
我花了很多时间在网上研究如何应用这个解决方案,但还没有找到如何实现这个工作的方法。
非常感谢任何帮助。
【问题讨论】:
标签: reactjs express https localhost next.js