【问题标题】:NodeJS Firebase Functions Fails After DeploymentNodeJS Firebase 功能在部署后失败
【发布时间】:2020-05-23 04:02:59
【问题描述】:

我有一个 NodeJS 并使用 Firebase 功能。在 localhost 上运行时,它正在发送预期的 JSON。将其部署到 Firebase 后,尝试访问端点时出现以下错误:

TypeError: Cannot read property 'stack' of undefined
    at getErrorDetails (/worker/worker.js:365:14)
    at logAndSendError (/worker/worker.js:579:12)
    at process.<anonymous> (/worker/worker.js:854:5)
    at emitTwo (events.js:126:13)
    at process.emit (events.js:214:7)
    at emitPendingUnhandledRejections (internal/process/promises.js:108:22)
    at process._tickDomainCallback (internal/process/next_tick.js:230:7)

前端返回如下错误:

Access to XMLHttpRequest at 'https://vear-node.firebaseapp.com/xmlfeed' from origin 'http://localhost:3000' has been blocked by CORS policy: No 'Access-Control-Allow-Origin' header is present on the requested resource.

我怀疑这是一个 CORS 问题,因为我正在使用 Express cors 中间件,并且可以毫无问题地访问此服务器上的其他端点。

代码:

const app = express().use(cors());

app.get('/xmlfeed', cors(), async (request, response) => {
    const feedResponse = await getXMLFeedData();
    const json = { products: feedResponse };
    response.json(json);
});
export const getXMLFeedData = async (): Promise<any> => {
    try {
        const response = await axios.get('https://www.nae-vegan.com/extend/catalog_81.xml');

        const parsedResponse = await parseXMLResult(response);
        const jsonString = JSON.stringify(parsedResponse);
        const jsonObject = JSON.parse(jsonString);
        const formatted = await formatNAEProducts(jsonObject);

        return Promise.resolve(formatted);
    } catch (error) {
        return Promise.reject(error);
    }
};
const parseXMLResult = async (response: any): Promise<any> => {
    var parsedResult: any = undefined;

    try {
        await parser.parseString(response.data, (err, result) => {
            parsedResult = result;
        });

        return Promise.resolve(parsedResult);
    } catch (error) {
        return Promise.reject(error);
    }
};

端点:https://vear-node.firebaseapp.com/xmlfeed

有谁知道在本地工作完美部署后会发生什么错误?

谢谢!

【问题讨论】:

  • 请编辑问题以显示显示问题的完整、最少的代码。现在我们看不到 getXMLFeedData() 做了什么,也没有任何代码显示名为 stack 的属性。
  • @DougStevenson 用更多代码更新了这个问题。没有称为堆栈的属性,这就是为什么我对它的来源感到困惑。
  • 来自快递。 @dcotter 你解决了这个问题吗?你还记得怎么做吗?

标签: node.js firebase express cors google-cloud-functions


【解决方案1】:

您必须允许所有 cors 来源请求进入您的标头。由于您使用的是 express 框架,因此您必须将其包含在您的 app.use 方法中。检查下面的代码。

app.use((req, res) => {
  res.header("Access-Control-Allow-Origin", "*");
  res.header("Access-Control-Allow-Headers", "Origin, X-Requested-With, Content-Type, Accept");
});

【讨论】:

  • 我认为这不是 CORS 问题。添加这些标题会产生相同的错误。我也在使用像 const app = express().use(cors()); 这样的 Express CORS,它启用了所有 CORS 请求 expressjs.com/en/resources/middleware/cors.html
猜你喜欢
  • 2021-12-29
  • 2020-11-13
  • 1970-01-01
  • 2018-12-06
  • 1970-01-01
  • 2021-02-26
  • 2023-04-01
  • 2021-10-05
  • 1970-01-01
相关资源
最近更新 更多