我一直在尝试 Symfony 2.2、FOSRest Bundle(使用 JMS Serializer)和使用 MongoDB 的 Doctrine ODM。
经过数小时试图弄清楚如何正确设置 FOSRest Bundle 后,我仍然遇到了一些麻烦:我有一个非常简单的路线,可以返回产品和价格列表。每当我请求 HTML 格式时,我都会得到正确的响应,但如果我请求任何其他格式(JSON、XML),我会收到错误消息:
[{"message": "Resources are not supported in serialized data. Path: Monolog\\Handler\\StreamHandler -> Symfony\\Bridge\\Monolog\\Logger -> Doctrine\\Bundle\\MongoDBBundle\\Logger\\Logger -> Doctrine\\Bundle\\MongoDBBundle\\Logger\\AggregateLogger -> Doctrine\\ODM\\MongoDB\\Configuration -> Doctrine\\MongoDB\\Connection -> Doctrine\\ODM\\MongoDB\\LoggableCursor",
"class": "JMS\\Serializer\\Exception\\RuntimeException",...
你可以在这里看到完整的错误信息
我当前的设置非常简单:我创建了一个到控制器的路由,该控制器返回产品列表和价格(我按照这个示例创建了产品文档)。
这是路线:
rest_product:
type: rest
resource: Onema\RestApiBundle\Controller\ProductController
这是控制器:
<?php
namespace Onema\RestApiBundle\Controller;
use Symfony\Component\HttpKernel\Exception\NotFoundHttpException;
use FOS\RestBundle\Controller\FOSRestController;
use FOS\RestBundle\Routing\ClassResourceInterface;
use FOS\Rest\Util\Codes;
use JMS\Serializer\SerializationContext;
use Onema\RestApiBundle\Document\Product;
class ProductController extends FOSRestController implements ClassResourceInterface
{
public function getAction()
{
$dm = $this->get('doctrine_mongodb')->getManager();
$products = $dm->getRepository('RestApiBundle:Product')->findAll();
if(!$products)
{
throw $this->createNotFoundException('No product found.');
}
$data = array('documents' => $products);
$view = $this->view($data, 200);
$view->setTemplate("RestApiBundle:Product:get.html.twig");
return $this->handleView($view);
}
}
这是从控制器 Resources/Product/get.html.twig 调用的视图:
<ul>
{% for document in documents %}
<li>
{{ document.name }}<br />
{{ document.price }}
</li>
{% endfor %}
</ul>
有什么想法为什么这对一种格式可以正常工作,而其他格式不能正常工作?我应该设置什么额外的东西吗?
更新: 这是我一直在使用的配置值。在 app/config/config.yml 结束时,我有这个:
sensio_framework_extra:
view: { annotations: false }
router: { annotations: true }
fos_rest:
param_fetcher_listener: true
body_listener: true
format_listener: true
view:
formats:
json: true
failed_validation: HTTP_BAD_REQUEST
default_engine: twig
view_response_listener: 'force'
解决方法:
做更多的研究我遇到了另一个错误,这导致我提出这个问题和答案:
https://stackoverflow.com/a/14030646/155248
Doctrine\ODM\MongoDB\LoggableCursor
一旦我通过将每个结果添加到这样的数组中来摆脱它:
$productsQ = $dm->getRepository('RestApiBundle:Product')->findAll();
foreach ($productsQ as $product) {
$products[] = $product;
}
return $products;
我开始以正确的格式获得结果。这是一种蹩脚的解决方案,仍然希望找到更好的解决方案。