我在ReactJs中使用Fetch向api Moleculer发送请求,如下所示:
var data ={
'ordername' : 'PUG',
'receivername' : 'AnSama'
}
fetch(url,{
method: 'POST',
header: {
'Accept': 'application/json',
'Content-Type': 'application/json',
},
body : data
})
.then(res => {return res.json()})
.then(
(result) => {
alert(JSON.stringify(result));
},
(error) => {
alert('error');
}
)然后,我想在Moleculer (NodeJS框架)中获得请求体。我该怎么做呢?
发布于 2018-04-10 03:52:03
在Moleculer API Gateway中,JSON主体总是被解析的,并且可以通过ctx.params访问。如果要向服务发送标头值,请使用路由器设置中的onBeforeHook。
broker.createService({
mixins: [ApiService],
settings: {
routes: [
{
path: "/",
onBeforeCall(ctx, route, req, res) {
// Set request headers to context meta
ctx.meta.userAgent = req.headers["user-agent"];
}
}
]
}
});发布于 2018-07-06 13:08:11
除了@Icebob回答之外,如果您的POST API处理异步请求(很可能会)&返回一个承诺。下面是一个例子(这就是我们的用法):
actions : {
postAPI(ctx) {
return new this.Promise((resolve, reject) => {
svc.postdata(ctx, (err, res) => {
if (err) {
reject(err);
} else {
resolve(res);
}
});
})
.then((res) => {
return res;
}, (err) => {
return err;
});
}
}https://stackoverflow.com/questions/49189345
复制相似问题