服务器端“流星”上的发布请求正文为空(错误503)

时间:2020-06-04 02:08:02

标签: javascript node.js meteor axios

我使用Axios将数据发送到API端点。在控制台的Network端,请求正文具有正确的数据。在Meteor服务器端,params和body均为空,并在控制台上引发503错误。

我阅读了类似的问题,并确保将content-type设置为application\json,我尝试将mode设置为no-cors,我正在呼叫本地端点。

客户端代码

const modifyPackage = () => {

            const requestContent = {
                "filePath": package.file.path,
                "data": data
            };
            const requestConfig = {
                headers: {
                    "Content-Type": "application/json"
                }
            }

            axios.post('/modifyPackage',requestContent,requestConfig)
            .then((response) => {
                console.log(response);
            }).catch ((err) => {
                console.log(err);
            });
        }   
        modifyPackage();

服务器端代码

  Picker.middleware( bodyParser.urlencoded( { extended: false } ) );
  Picker.middleware( bodyParser.json() );

  Picker.route('/modifyPackage',(params, req,res,next) => {
    console.dir("## BODY ##");
    console.dir(req.body);
    if (req.method == "POST") {
      const modifiedContent = req.body.data;
      const pathString = req.body.filePath;
      console.dir(pathString);
      console.dir(modifiedContent);

      fs.writeFile(pathString, modifiedContent, (err,data) => {
        if (data) {
          console.dir(data);
        }
        res.end();
      });
    } else {
      console.dir("Not Post")
      res.end("No Response");
    }
  });

2 个答案:

答案 0 :(得分:1)

503错误服务器端错误

const modifiedContent = req.body.data;
const pathString = req.body.filePath;

答案 1 :(得分:0)

我不认识Picker。您可以使用内置的Meteor Webapp软件包。

import { WebApp } from 'meteor/webapp';
import connectRoute from 'connect-route';

WebApp.connectHandlers.use(connectRoute((router) => {
  router.post('/modifyPackage/:someParam/:otherParam', (req, res, next) => {
    // some logic here.

    res.writeHead(200);
    res.end('some data');
  });
}));