在 Zend Framework 2 中,内容协商发生在视图层,我对此非常满意。我的控制器中的一个示例:
public function viewAction()
{
$id = $this->params('id');
$user = $this->getRepository()->findUser();
return new ViewModel(array(
'user' => $user,
));
}
这要么呈现 view.phtml 模板以返回 html,要么将用户对象转换为 JSON 响应。所谓的视图策略决定了如何根据请求来渲染响应。
我的 webapp 中的“REST”应用程序流程
这种类型的内容协商适用于许多用例:
/user
或indexAction()
返回用户数组 => 可能的 JSON html;/user/1
或viewAction()
返回用户对象 => 可能的 html 或 JSON(上面的示例);/user/1/update
或updateAction()
返回一个 html 表单。出现错误时,此 url 的 POST 将返回 html 或 JSON。或者在成功时它重定向到viewAction()
并因此返回用户的新版本 => html 和 JSON 再次可能;/user/create
或createAction()
返回一个 html 表单。出现错误时,此 url 的 POST 将返回 html 或 JSON。或者在成功时,它viewAction()
可能再次重定向到刚刚创建的用户 => html 和 JSON
我的问题
在一些用例中,内容协商在控制器层中是“必需的”。我不确定我是否忽略了一些可能性:是否有我可以在以下情况下使用的选项?
- 删除用户:POST 到
/user/1/delete
. 如果是 html 视图,您将被重定向到用户列表(现在已删除的用户已丢失)。如果你想要一个 JSON 响应,你想要返回 200 OK 和一个带有删除成功消息的 JSON 对象。 - 对博客文章发表评论。如果是 html 视图,您将被重定向到您看到附加评论的帖子。如果您要求 JSON 响应,您希望返回 200 OK 和一个带有您刚刚放置的评论的 JSON 对象。
我的目标是不复制视图层中已经存在的内容协商。这也会使我的控制器更胖,因为我现在有两种可能的响应(JSON 与 html),但这可能不是唯一的情况。如果我以后想要支持 XML 或其他格式,我会为这些响应类型的每个操作切换。