【发布时间】:2023-03-24 08:54:01
【问题描述】:
我的 Next.js 应用部署在 Firebase 上。我使用自定义服务器(server.ts)来启动应用程序(节点 src/server.ts)。下一个代码是 server.ts 和 firebaseFunctions.js。 server.ts 正在本地工作,因此代理正在工作。 为什么它在 fierbase 上不起作用?请告诉我解决方案。
// @ts-ignore
const express = require("express");
const next = require("next");
const { createProxyMiddleware } = require("http-proxy-middleware");
const port = parseInt(process.env.PORT, 10) || 3000;
const dev = process.env.NODE_ENV !== "production";
const API_URL = process.env.API_URL;
const app = next({ dev });
const handle = app.getRequestHandler();
app.prepare().then(() => {
const server = express();
console.log("sercer")
server.use(
"/api",
createProxyMiddleware({
target: "https://tus-schedule-api.herokuapp.com",
changeOrigin: true,
})
);
server.get("/super_test", (req, res) => {
return res.status(200).send();
});
server.all("*", (req, res) => {
return handle(req, res);
});
server.listen(port, (err) => {
if (err) throw err;
console.log(`> Ready on http://localhost:${port}`);
});
});
const { join } = require("path");
const { https } = require("firebase-functions");
const { default: next } = require("next");
const isDev = process.env.NODE_ENV !== "production";
const nextjsDistDir = join("src", require("./src/next.config.js").distDir);
const nextjsServer = next({
dev: isDev,
conf: {
distDir: nextjsDistDir,
},
});
const nextjsHandle = nextjsServer.getRequestHandler();
exports.nextjsFunc = https.onRequest((req, res) => {
return nextjsServer.prepare().then(() => nextjsHandle(req, res));
});
【问题讨论】:
标签: typescript firebase proxy next.js