我如何在Express Node.js中console.log res.body

时间:2019-01-27 21:40:29

标签: node.js

我正在使用“ 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,但无济于事。

1 个答案:

答案 0 :(得分:0)

尝试

   console.log(res); 
   console.log(res.body)
  courses.push(course);
  res.status(200).json(course);

console.log发送请求前的请求正文