Symfony 框架内置序列化工具教程(二)

Symfony 框架内置序列化工具教程(二)

Chris Yue No Comment
Posts

Symfony 框架默认使用 ObjectNormalizer,这在上一篇文章里已经提到。但其实除了默认的方式,你也可以有更多的选择,比如使用 GetSetMethodNormalizer,你需要做的也只是注册一个服务:

定义一个服务为 Normalizer 的关键其实就是最后一句对 tags的定义。只要定义一个服务为 serializer.normalizer 他就成了 serializer 服务里的一个 Normalizer 了。

GetSetMethodNormalizer 的构造函数是可以允许不需要任何的参数的,但这样就不能使用 Annotation 来定义上篇文章所说的 Serialization Group 了;另外当注册了新的 Normalizer 的时候,config.yml 里的 name_converter 也不起作用(此设置只对框架自带的 Normalizer 有效果),所以在注册这个 Normalizer 服务时,最好模仿框架自带的 Normalizer,将读 Annotation 配置的 @serializer.mapping.class_metadata_factory 服务和 @serializer.name_converter.camel_case_to_snake_case 注入到服务里:

Circular Reference Handler

Symfony 的文档中提到序列化是一个很复杂的话题,的确如此,比如要小心处理循环引用的问题,比如说一个 User 有 1 个 Group,但 Group 里又有 n 个 User,如果序列化这样的 User 对象,将会自动序列化这个 User 的 Group 对象,而序列化 Group 对象的时候,又会自动序列化 Group 里的所有 User 对象…… 好在 Symfony 的序列化工具可设置 Circular Reference Handler,这样就可以按自己的定义的方式解决这个问题:

可能你会有疑问,那之前的 ObjectNormalizer 呢?据我所观察,当一个对象遇到适合它的 Normalizer 的时候,一旦被这个 Normalizer 处理过,其他排在后面的 Normalizer 就不会处理这个对象了。框架自带的 Normalizer 是设置了 -1000的优先级的,所以这里一旦我们自己的 GetSetMethodNormalizer 被注册为服务,就不会使用框架自带的 ObjectNormalizer 了。

下一章节

Symfony 框架内置序列化工具教程(二) by Chris Yue is licensed under a Creative Commons Attribution-NonCommercial-NoDerivatives 4.0 International License.

微信赞赏码

文章不错,我要帮站长分担建站费!
天使投赏人

发表评论

eighty two + = 90