我正在使用“ express”:“ ^ 4.16.2”和“ morgan”:“ ^ 1.9.1”, 但我无法记录响应正文。 我在构建res后通过console.log res.body进行了故障排除。它可以显示整个资源,但如果仅记录res.body,则显示未定义。
app.use(express.json()); //build-in
app.use(express.urlencoded({extended: true}));
app.use(morgan(loggerFormat, { stream: accessLogStream }));
......
//***** Cannot get response body */
// morgan.token('id', (req) => { return req.id; });
// morgan.token('reqBody', req => { return JSON.stringify(req.body) });
// morgan.token('resBody', (req, res) => {return JSON.stringify(res.body)});
// var loggerFormat = ':date[iso] :id :method :url \n :reqBody \n :status \n :resBody';
// app.use(morgan(loggerFormat, { stream: accessLogStream })); // 3rd party
app.post('/api/courses', (req, res) => {
const { error } = validateCourse(req.body);
if(error) return res.status(400).json({"error": error.details[0].message});
const course = {
id: parseInt(courses[courses.length-1].id) + 1,
name: req.body.name,
tutor: req.body.tutor
};
courses.push(course);
res.status(200).json(course);
console.log(res);
console.log(res.body);
});
我尝试由提供的解决方案 Node.js + Express - How to log the request body and response body,但无济于事。
答案 0 :(得分:0)
尝试
console.log(res);
console.log(res.body)
courses.push(course);
res.status(200).json(course);
console.log发送请求前的请求正文