symfony2 框架默认使用 objectnormalizer,这在上一篇文章里已经提到。但其实除了默认的方式,你也可以有更多的选择,比如使用 getsetmethodnormalizer,你需要做的也只是注册一个服务:
services: app.serializer.method_normalizer: class: Symfony\Component\Serializer\Normalizer\GetSetMethodNormalizer tags: - { name: serializer.normalizer }定义一个服务为 Normalizer 的关键其实就是最后一句对 tags的定义。只要定义一个服务为 serializer.normalizer他就成了 serializer服务里的一个 Normalizer 了。
易优小程序是基于前端开源小程序+后端易优cms+标签化API接口,是一套开源、快速搭建个性化需求的小程序CMS。轻量级TP底层框架,前后端分离,标签化API接口可对接所有小程序,支持二次开发。即使小白用户也能轻松搭建制作一套完整的线上版小程序。微信工程机械小程序模板主要特点:1、代码开源,支持二次修改。2、微信原生写法,兼容性更好,代码可读性更强。3、功能接口完整,支持eyoucms大部分功能ap
0
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注入到服务里:
services: app.serializer.method_normalizer: class: Symfony\Component\Serializer\Normalizer\GetSetMethodNormalizer arguments: - '@serializer.mapping.class_metadata_factory' - '@serializer.name_converter.camel_case_to_snake_case' tags: - { name: serializer.normalizer }Symfony2 的文档中提到序列化是一个很复杂的话题,的确如此,比如要小心处理循环引用的问题,比如说一个 User 有 1 个 Group,但 Group 里又有 n 个 User,如果序列化这样的 User 对象,将会自动序列化这个 User 的 Group 对象,而序列化 Group 对象的时候,又会自动序列化 Group 里的所有 User 对象…… 好在 Symfony2 的序列化工具可设
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号