我使用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");
}
});
答案 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');
});
}));