Ben*_*Ben 3 https localhost express reactjs next.js
系统信息
目标
在本地主机上通过HTTPS使用SSL服务Web应用程序
已经做了什么
server.jsserver.js内部package.json脚本。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);
});
Run Code Online (Sandbox Code Playgroud)
额外的信息
使用初始化时,该应用当前可以运行yarn dev。我尝试使用此答案通过https服务该应用程序,但无法弄清楚如何使用NextJS将其应用于当前设置。
我花了很多时间研究网络上如何应用此解决方案,但还没有找到实现此工作的方法。
任何帮助是极大的赞赏。
您只需要使用模块的createServer方法https。
const { createServer } = require('https');
const { parse } = require('url');
const { readFileSync } = require('fs');
const next = require('next');
const port = 3000;
const dev = process.env.NODE_ENV !== 'production';
const app = next({ dev });
const handle = app.getRequestHandler();
const httpsOptions = {
key: readFileSync('./certificates/key.pem'),
cert: readFileSync('./certificates/cert.pem')
};
app.prepare()
.then(() => {
createServer(httpsOptions, (req, res) => {
const parsedUrl = parse(req.url, true);
handle(req, res, parsedUrl);
}).listen(port, err => {
if (err) throw err;
console.log(`> Ready on https://localhost:${port}`);
})
});
Run Code Online (Sandbox Code Playgroud)
其他答案似乎只是放弃快递......在服务器代码和证书遇到一些困难后找到了解决方案,因此希望可以为其他人省去麻烦!
首先,在这里创建本地主机证书的可靠建议:https : //letsencrypt.org/docs/certificates-for-localhost/
其次,提供 HTTP/HTTPS 与 next js 和 express 的简单代码:
const next = require('next');
const express = require('express');
const http = require('http');
const https = require('https');
const fs = require('fs');
const ports = {
http: 3080,
https: 3443
}
const dev = process.env.NODE_ENV !== 'production';
const app = next({ dev });
const handle = app.getRequestHandler();
const server = express();
const options = {
key: fs.readFileSync('localhost.key'),
cert: fs.readFileSync('localhost.crt'),
};
app.prepare().then(() => {
server.all('*', (req, res) => {
return handle(req, res)
});
http.createServer(server).listen(ports.http);
https.createServer(options, server).listen(ports.https);
});
Run Code Online (Sandbox Code Playgroud)
值得注意的是,可以省略或重定向任一端口。
| 归档时间: |
|
| 查看次数: |
1616 次 |
| 最近记录: |