13

我刚刚开始使用 REST,我一直在阅读这篇文章和提到的关于 REST响应代码的。然而,当我查看 Play 的Controller类时,它似乎仅限于返回

  • 200 - 好的
  • 301 - 永久移动
  • 302 - 找到
  • 304 - 未修改
  • 400 - 错误请求
  • 401 - 未授权
  • 403 - 禁止
  • 404 - 未找到
  • 5xx

这似乎遗漏了一些可能有用的代码:

  • 201 - 已创建(成功的 JSON 帖子的良好响应?)
  • 202 - 接受(对于排队的请求)
  • 204 - 无内容(成功 PUT/POST/DELETE 的可能响应)
  • 307 - 临时重定向
  • 405 - 不允许的方法
  • 406 - 不可接受
  • 409 - 冲突
  • 410 - 走了
  • 415 - 不支持的媒体类型(当没有定义 JSON 模板时,这似乎是对 JSON 格式请求的适当响应)

毕竟那些都不需要吗?Play 会自动处理这些情况吗?

此外,一个控制器似乎无法很好地处理同一资源的 REST 请求和正常网页请求,因为网页总是以200. 我在那里缺少什么吗?

4

2 回答 2

12

查看play.mvc.Http.StatusCode对象的Play Source code(Play 1.1),Play似乎有以下代码

public static final int OK = 200;
public static final int CREATED = 201;
public static final int ACCEPTED = 202;
public static final int PARTIAL_INFO = 203;
public static final int NO_RESPONSE = 204;
public static final int MOVED = 301;
public static final int FOUND = 302;
public static final int METHOD = 303;
public static final int NOT_MODIFIED = 304;
public static final int BAD_REQUEST = 400;
public static final int UNAUTHORIZED = 401;
public static final int PAYMENT_REQUIERED = 402;
public static final int FORBIDDEN = 403;
public static final int NOT_FOUND = 404;
public static final int INTERNAL_ERROR = 500;
public static final int NOT_IMPLEMENTED = 501;
public static final int OVERLOADED = 502;
public static final int GATEWAY_TIMEOUT = 503;

这将表明您已识别的某些代码的确认,例如 201、202、204。但是,值 307、405、406、409、410 和 415 不存在。

此外,201、202、204 被确认,但在源代码中的其他任何地方都没有引用。因此,除非 Netty 服务器或提供的其中一个 jar 文件正在为 Play 管理这些(我不确定它是否可以做到),否则我无法看到 Play 如何在不了解代码库的情况下神奇地处理这些情况。

查看 renderJSON 的代码,它似乎没有将状态代码设置为发送回结果的一部分(因此使用默认的 200),因此以下 hack可能有效。

public static void myJsonAction() {
    response.status = 201;
    renderJSON(jsonString); // replace with your JSON String
}
于 2010-12-18T10:43:17.430 回答
9

在当前的 Play 版本中,您必须status()改用。例子:

status(201, jsonData);

在 Scala 中,它应该像从官方文档中获取的这个示例一样工作:

Status(488)("Strange response type")
于 2014-02-17T12:31:24.100 回答