POST请求无法解决问题,导致500内部服务器错误

时间:2014-03-17 18:53:15

标签: node.js rest restify

我在示例REST API中遇到POST请求的问题。

我只有四种回调方法:

app.get '/tasks', task.getAll
app.get '/tasks/done', task.getDone
app.get '/tasks/notdone', task.withoutDone
app.post '/tasks', task.newTask

models = require'../ models / models.js'

exports.getAll = (req, res, next) ->
  models.Task.find {}, 'title description, done', (err, tasks) ->
    if err then err
    res.send tasks
    do next

exports.getDone = (req, res, next) ->
  models.Task.find {done: true}, (err, tasks) ->
    if err then err
    res.send tasks
    do next

exports.withoutDone = (req, res, next) ->
  models.Task.find {done: false}, (err, tasks) ->
    if err then err
    res.send tasks
    do next

exports.newTask = (req, res, next) ->
  if req.params.title is undefined
    return next new restify.InvalidArgumentError 'Title is needed'

  taskData = 
    title: req.params.title
    description: req.params.description
    done: req.params.done

  task = new Task(taskData)
  task.save (err, data) ->
    if err
      return next new restify.InvalidArgumentError(JSON.stringify(error.errors))
    else
      res.json(data)

    res.send 201, task

因此,您可以在唯一的要点中找到代码here

我跑步时的痕迹

curl -i -X POST -d '{"title": "hello world", description: "lorem ipsum dolor amet", "done": true}' http://localhost:8080/tasks

在回复中给我一个500内部负责人:

HTTP/1.1 500 Internal Server Error
Content-Type: application/json
Content-Length: 59
Access-Control-Allow-Origin: *
Access-Control-Allow-Headers: Accept, Accept-Version, Content-Length, Content-MD5, Content-Type, Date, Api-Version, Response-Time
Access-Control-Allow-Methods: GET, POST
Access-Control-Expose-Headers: Api-Version, Request-Id, Response-Time
Connection: Keep-Alive
Content-MD5: QFnWTtR6KfhLtGqWpGWZog==
Date: Mon, 17 Mar 2014 15:12:00 GMT
Server: task-API
Request-Id: 7d71a510-ade6-11e3-bd80-292785b198e2
Response-Time: 1

{"code":"InternalError","message":"restify is not defined"}

1 个答案:

答案 0 :(得分:4)

在错误处理方面,Restify具有与expressjs类似的设计。它吞下未捕获的异常并将它们以JSON格式发送回浏览器,并伴有HTTP 500错误,而不是在控制台上打印它们。

消息“restify is not defined”通常意味着您忘记在脚本中的某处调用var restify = require('restify');

您还可以使用以下代码段在控制台上查明错误的位置:

server.on('uncaughtException', function (req, res, route, err) {
    console.log('uncaughtException', err.stack);
});