Google 函数在访问 body 的值时中断

问题描述 投票:0回答:3

我想使用谷歌函数来处理一些发布数据并返回它。虽然它在本地运行良好,但我无法让它在谷歌服务器上运行。

这个“功能”:

exports.helloWorld = (req, res) => {
  res.set('Access-Control-Allow-Methods', 'GET, HEAD, OPTIONS, POST');
  res.set('Access-Control-Allow-Headers', 'Origin, X-Requested-With, Content-Type, Accept');
  res.set('Access-Control-Allow-Origin', '*');
  //res.status(200).send({"req.body.message": req.body.message});
  res.status(200).send({"req.body.message.length": req.body.message.length});
  return;
};

此请求将失败:

fetch("https://us-central1-{myproject}.cloudfunctions.net/demo",
    {
      body: JSON.stringify({"message":"hello"}),
      method: "POST",
      headers: {
        'Content-Type': 'application/json'
      },
      mode: "cors"
    }
  ).then(response => response.json())
    .then(d => console.log(d))

TypeError: Cannot read property 'length' of undefined
    at exports.helloWorld (/user_code/index.js:17:76)
    at ...

而与其他 res.status... 注释行相同的方法将起作用并返回 {req.body.message: "hello"}

在本地这是有效的..知道为什么这会破坏吗?

node.js google-cloud-platform
3个回答
2
投票

问题是,我没有检查 request.method。浏览器发出了预检 OPTIONS 请求,但这次失败了,因为那里没有 req.body.message。所以真正的 POST 请求从未发生过。

这解决了它:

  exports.helloWorld = (req, res) => {
      if (req.method === 'POST') {
      res.set('Access-Control-Allow-Origin', '*')
        .set('Access-Control-Allow-Methods', 'GET, HEAD, OPTIONS, POST')
        .set('Access-Control-Allow-Headers', 'Origin, X-Requested-With, Content-Type, Accept')
        .set('Access-Control-Allow-Credentials', false)
        .status(200).send({"req.body.message.length": req.body.message.length });
      }
      else {
        res.set('Access-Control-Allow-Origin', '*')
        .set('Access-Control-Allow-Methods', 'GET, HEAD, OPTIONS, POST')
        .set('Access-Control-Allow-Headers', 'Origin, X-Requested-With, Content-Type, Accept')
        .set('Access-Control-Allow-Credentials', false)
        .status(200).send();
      }
    };

0
投票

尝试如下操作:

res.set('Access-Control-Allow-Origin', '*')
    .set('Access-Control-Allow-Methods', 'GET, HEAD, OPTIONS, POST')
    .set('Access-Control-Allow-Headers', 'Origin, X-Requested-With, Content-Type, Accept')
    .set('Access-Control-Allow-Credentials', false)
    .status(200).send({"req.body.message": req.body.message.length });

0
投票

刚刚撞了一下我的头,cors 会帮助你轻松做到这一点...... 在你的functions/index.js中:

// import cors
const cors = require('cors')({origin: true});
exports.chat = onRequest(async (req, res) => {
cors(req, res, async () => {
    try {
        console.log(req.body)
        console.log(req.body.data)
        


        if (!req.body.data.message || !req.body.data.assistantId) {
            return res.status(400).json({error: "Required field is missing"});
        }

        const userMessage = req.body.data.message;
        const assistantId = req.body.data.assistantId;


<the rest of your code here>
© www.soinside.com 2019 - 2024. All rights reserved.