如何使用序列化器
编辑本页警告:您正在浏览的文档欧宝官网下载appob娱乐下载Symfony 3.0,现已不再维护。
读本页的更新版本用于Syob娱乐下载mfony 6.2(当前稳定版本)。
如何使用序列化器
对对象和不同格式(例如JSON或XML)进行序列化和反序列化是一个非常复杂的主题。ob娱乐下载Symfony带有一个序列化器组件,它为您提供了一些可以用于解决方案的工具。
实际上,在开始之前,请通过阅读序列化器组件.
激活序列化器
的序列化器
默认情况下,该服务不可用。要打开它,请在配置中激活它:
- YAML
- XML
- PHP
1 2 3 4 5
# app / config / config.yml框架:#……序列化器:启用:真正的
1 2 3 4 5
<!--app/config/config.xml --><框架:配置><!--...--><框架:序列化器启用=“真正的”/>框架:配置>
1 2 3 4 5 6 7
/ / app / config / config . php$容器->loadFromExtension (“框架”,数组(/ /……“序列化器”= >数组(“启用”= >真正的,),));
使用序列化器服务
启用后,序列化器
Service可以被注入到你需要的任何服务中,也可以像下面这样用在控制器中:
12 3 4 5 6 7 8 9 10 11 12 13 14
/ / src / AppBundle /控制器/ DefaultController.php名称空间AppBundle\控制器;使用ob娱乐下载\包\FrameworkBundle\控制器\控制器;类DefaultController扩展控制器{公共函数indexAction(){$序列化器=$这->get (“序列化器”);/ /……}}
添加标准化器和编码器
启用后,序列化器
服务将在容器中可用,并将装入两个编码器(JsonEncoder而且XmlEncoder)及ObjectNormalizer标准化者.
您可以通过标记为来加载归一化器和/或编码器serializer.normalizer而且serializer.encoder.还可以设置标记的优先级以决定匹配顺序。
下面是一个关于如何加载GetSetMethodNormalizer:
- YAML
- XML
- PHP
1 2 3 4 5 6 7
# app / config / services.yml服务:get_set_method_normalizer:类:ob娱乐下载Symfony \组件\ \标准化者\ GetSetMethodNormalizer进行序列化公众:假标签:-{名称:serializer.normalizer}
1 2 3 4 5 6
<!--app/config/services.xml --><服务><服务id=“get_set_method_normalizer”类=“ob娱乐下载Symfony \序列化器\ \组件标准化者\ GetSetMethodNormalizer”公共=“假”><标签的名字=“serializer.normalizer”/>服务>服务>
1 2 3 4 5 6 7 8 9
/ / app / config / services.php使用ob娱乐下载\组件\DependencyInjection\定义;$定义=新定义(“ob娱乐下载Symfony \序列化器\ \组件标准化者\ GetSetMethodNormalizer '));$定义->setPublic (假);$定义->addTag (“serializer.normalizer”);$容器->setDefinition (“get_set_method_normalizer”,$定义);
使用序列化组注释
启用序列化组注释配置如下:
- YAML
- XML
- PHP
1 2 3 4 5
# app / config / config.yml框架:#……序列化器:enable_annotations:真正的
1 2 3 4 5
<!--app/config/config.xml --><框架:配置><!--...--><框架:序列化器enable-annotations=“真正的”/>框架:配置>
1 2 3 4 5 6 7
/ / app / config / config . php$容器->loadFromExtension (“框架”,数组(/ /……“序列化器”= >数组(“enable_annotations”= >真正的,),));
接下来,添加@Groups注释并选择在序列化时使用哪些组:
1 2 3 4 5
$序列化器=$这->get (“序列化器”);$json=$序列化器->序列化($someObject,json的,数组(“组织”= >数组(“group1”)));
除了@Groups
注释,Serializer组件也支持Yaml或XML文件。当这些文件被存储在以下位置之一时,会自动加载:
- 的
serialization.yml
或serialization.xml
在资源/ config /
包的目录; - 所有
* .yml
而且* . xml
文件资源/ config /序列化/
包的目录。
启用元数据缓存
Serializer组件使用的元数据(例如组)可以被缓存以增强应用程序性能。实现学说\常见\缓存\缓存
接口可以使用。
服务杠杆APCu(和APC for PHP < 5.5)是内置的。
- YAML
- XML
- PHP
1 2 3 4 5
# app / config / config_prod.yml框架:#……序列化器:缓存:serializer.mapping.cache.apc
1 2 3 4 5
<!--app/config/config_prod.xml --><框架:配置><!--...--><框架:序列化器缓存=“serializer.mapping.cache.apc”/>框架:配置>
1 2 3 4 5 6 7
/ / app / config / config_prod.php$容器->loadFromExtension (“框架”,数组(/ /……“序列化器”= >数组(“缓存”= >“serializer.mapping.cache.apc”,),));
进一步使用序列化器
ApiPlatform提供API系统支持JSON-LD而且Hydra核心词汇超媒体格式。它构建在Symfony Framework及其Serob娱乐下载ializer组件之上。它提供了自定义规范化器、自定义编码器、自定义元数据和缓存系统。
如果您想充分利用Symfony Serializer组件的全部功能,请看看这个包是如何工作的ob娱乐下载。