- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
我目前正在学习如何使用 Symfony 3(带有 FOSRestBundle)和 JMS Serializer 来实现一个相对简单的 API。我最近一直在尝试实现指定作为消费客户端的能力,哪些字段应该在响应中返回(请求的实体和关系中的字段)。例如;
/posts
将返回所有 Post
实体属性(例如标题、正文、posted_at 等),但没有关系。 /posts?fields[]=id&fields[]=title
将只返回帖子的 ID 和标题(但同样,没有关系)/posts?include[]=comment
将包含上述内容,但具有 Comment
关系(及其所有属性)/posts?include[]=comment&include[]=comment.author
会像上面那样返回,但也会在每条评论中包含作者尝试和实现这种做法明智吗?我最近对此进行了大量研究,但我看不出我可以 1) 限制对单个字段的检索,以及 2) 仅在明确要求时才返回相关实体。
我对这个概念有过一些初步的尝试,但是即使确保我的存储库只返回 Post 实体(即没有评论),JMS Serializer 似乎会触发所有相关实体的延迟加载而且我似乎无法停止这个。我看到了一些链接,例如 this example然而修复似乎不起作用(例如在该链接中,注释掉的 $object->__load()
调用在原始代码中无论如何都不会到达。
我已经实现了 relationship-based example of this using JMSSerializer's Group
functionality但是不得不这样做感觉很奇怪,当我理想地能够构建一个 Doctrine Querybuilder 实例,动态添加 andWhere()
调用并让序列化程序只返回准确的数据而不加载关系时。
我很抱歉在这方面乱七八糟,但我已经坚持了一段时间,非常感谢任何意见!谢谢。
最佳答案
您应该能够使用 Groups
实现您想要的效果排除策略。
例如,您的 Post
实体可能看起来像这样:
use JMS\Serializer\Annotation as JMS;
/**
* @JMS\ExclusionPolicy("all")
*/
class Post
{
/**
* @ORM\Id
* @ORM\GeneratedValue(strategy="IDENTITY")
* @ORM\Column(type="integer")
*
* @JMS\Expose
* @JMS\Groups({"all", "withFooAssociation", "withoutAssociations"})
*/
private $id;
/**
* @ORM\Column(type="string")
*
* @JMS\Expose
* @JMS\Groups({"all", "withFooAssociation", "withoutAssociations"})
*/
private $title;
/**
* @JMS\Expose
* @JMS\Groups({"all", "withFooAssociation"})
*
* @ORM\OneToMany(targetEntity="Foo", mappedBy="post")
*/
private $foos;
}
像这样,如果您的 Controller 操作返回 View
使用 serializerGroups={"all"}
,响应将包含您实体的所有字段。
如果它使用 serializerGroups={"withFooAssociation"}
,响应将包含 foos[]
关联条目及其公开字段。
而且,如果它使用 serializerGroups={"withoutAssociation"}
, foos
关联将被序列化程序排除,因此不会呈现。
要从关联的目标实体(Foo
实体)中排除属性,请使用相同的 Groups
在目标实体属性上以获得链式序列化策略。
当你的序列化结构良好时,你可以动态设置 serializerGroups
在你的 Controller 中,为了根据 include
使用不同的组和 fields
参数(即 /posts?fields[]=id&fields[]=title
)。示例:
// PostController::getAction
use JMS\Serializer\SerializationContext;
use JMS\Serializer\SerializerBuilder;
$serializer = SerializerBuilder::create()->build();
$context = SerializationContext::create();
$groups = [];
// Assuming $request contains the "fields" param
$fields = $request->query->get('fields');
// Do this kind of check for all fields in $fields
if (in_array('foos', $fields)) {
$groups[] = 'withFooAssociation';
}
// Tell the serializer to use the groups previously defined
$context->setGroups($groups);
// Serialize the data
$data = $serializer->serialize($posts, 'json', $context);
// Create the view
$view = View::create()->setData($data);
return $this->handleView($view);
希望我正确理解了您的问题,这足以帮助您。
关于php - 使用 Symfony/FosRestBundle/JMS Serializer 实现字段白名单的建议,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/36212327/
目前我有以下内容: $.ajax({ type: 'POST', url: this.action, data: $(this).serialize(), }); 这工作正常,
目前我有以下内容: $.ajax({ type: 'POST', url: this.action, data: $(this).serialize(), }); 这很好用,但
我知道什么是序列化,但对我来说,这是一个无法描述其含义的术语。 为什么我们称序列化为序列化?将对象转换为原始数据(以及膨胀/反序列化,就此而言)有什么意义?谁创造了这个术语,为什么? 最佳答案 它可能
是否可以将数据结构(使用 boost::serialization)序列化为字符串变量或缓冲区(而不是磁盘上的文件)? 最佳答案 当然,让它在stringstream上完成工作。 关于serializ
假设我有以下类型定义,它依赖于常量来指示记录成员的向量长度: type point_t is record x: std_logic_vector(X_WIDTH-1 downto 0);
我尝试序列化一个向量和一个 map 容器,并通过 cout 输出它们的值。然而,我很难理解boost输出的含义。我的代码如下所示: #include #include #include #
我正在尝试将序列化功能添加到我的 Rust 结构之一。这是一个日历事件,看起来像这样: #[derive(PartialEq, Clone, Encodable, Decodable)] pub st
正如主题所暗示的那样,在将大量数据序列化到文件时,我遇到了 boost::serialization 的一个小问题。问题在于应用程序的序列化部分的内存占用大约是被序列化对象内存的 3 到 3.5 倍。
在搜索解决方案时,我得到了 this和 this但我不清楚这个概念,所以无法实现:(。当我尝试更新数据库中的值(特别是日期时间对象)时会发生此错误。以下是我正在使用的代码:- var upd
我收到以下错误, 模板对象不可迭代 def get_AJAX(request, id): data = serializers.serialize("json", Template.objec
由于方便,我正在考虑对我的所有数据 i/o 使用 serialize() 和 deserialize()。但是,我不想在 Julia 更新中被不可读的文件所困扰。 serialize() 和 dese
我有一个通常使用 JMS Serializer 包序列化的实体。我必须在序列化中添加一些不驻留在实体本身中但通过一些数据库查询收集的字段。 我的想法是创建一个自定义对象,用实体字段填充字段并添加自定义
我正在尝试使用 XmlParser 从 xml 文件中删除和添加标签。以下是我在使用“grails run-app”命令部署的 grails 应用程序中执行时运行良好的代码块: def parser
我正在使用 MRUnit 测试 MultipleOutputs。测试用例失败并显示以下消息。 java.lang.ClassCastException: org.apache.hadoop.io.se
本文整理了Java中com.jme3.network.serializing.serializers.ZIPSerializer类的一些代码示例,展示了ZIPSerializer类的具体用法。这些代码
我有一个处理草图,需要与 USB 设备建立 2 个连接。我无法提前判断哪个设备是 USB0 哪个是 USB1。 (不是我至少知道) 其中一台设备发出问候语,另一台设备根本不回答。因此,我编写了带有简单
我在下面有这个代码,我来自 this forum我遵循了。它对我不起作用,但他们声称代码很好。我已经尝试了几种字符串比较方法,例如 string.equals(string)和标准==运营商,仍然没有
当我尝试调用特定的 Web 服务方法时,我收到“Unspecified error”。使用 XMLSpy 我发现参数对象还没有被序列化。 在生成的序列化程序源中,我注意到以下几行: if (!need
在 Rust 中编写 NEAR 智能合约,我的编译器似乎要求通过 API 发送的对象具有 Serialize trait,以及存储在区块链中的对象 BorshSerialize和 BorshDeser
我正在尝试 Kotlin 序列化。按照说明进行设置后,我得到了 Unresolved reference: serializer使用此代码构建错误: val serializer : KSeriali
我是一名优秀的程序员,十分优秀!