nilportugues / xml
输出有效的API响应的XML转换器。
1.0.0
2016-06-16 21:44 UTC
Requires
- php: >=5.5.0
- nilportugues/api-transformer: ^1.5
Requires (Dev)
- friendsofphp/php-cs-fixer: ^1.9
- phpunit/phpunit: 4.8.*
This package is auto-updated.
Last update: 2024-09-06 09:07:03 UTC
README
安装
使用Composer安装包
$ composer require nilportugues/xml
使用方法
给定一个PHP对象和一系列映射,XML转换器会将给定数据表示为XML对象。
例如,给定以下代码片段,定义一个博客文章和一些评论
$post = new Post( new PostId(9), 'Hello World', 'Your first post', new User( new UserId(1), 'Post Author' ), [ new Comment( new CommentId(1000), 'Have no fear, sers, your king is safe.', new User(new UserId(2), 'Barristan Selmy'), [ 'created_at' => (new DateTime('2015/07/18 12:13:00'))->format('c'), 'accepted_at' => (new DateTime('2015/07/19 00:00:00'))->format('c'), ] ), ] );
以及所有涉及的类的映射数组
use NilPortugues\Api\Mapping\Mapper; $mappings = [ [ 'class' => Post::class, 'alias' => 'Message', 'aliased_properties' => [ 'author' => 'author', 'title' => 'headline', 'content' => 'body', ], 'hide_properties' => [ ], 'id_properties' => [ 'postId', ], 'urls' => [ 'self' => 'http://example.com/posts/{postId}', 'comments' => 'http://example.com/posts/{postId}/comments' ], ], [ 'class' => PostId::class, 'alias' => '', 'aliased_properties' => [], 'hide_properties' => [], 'id_properties' => [ 'postId', ], 'urls' => [ 'self' => 'http://example.com/posts/{postId}', ], ], [ 'class' => User::class, 'alias' => '', 'aliased_properties' => [], 'hide_properties' => [], 'id_properties' => [ 'userId', ], 'urls' => [ 'self' => 'http://example.com/users/{userId}', 'friends' => 'http://example.com/users/{userId}/friends', 'comments' => 'http://example.com/users/{userId}/comments', ], ], [ 'class' => UserId::class, 'alias' => '', 'aliased_properties' => [], 'hide_properties' => [], 'id_properties' => [ 'userId', ], 'urls' => [ 'self' => 'http://example.com/users/{userId}', 'friends' => 'http://example.com/users/{userId}/friends', 'comments' => 'http://example.com/users/{userId}/comments', ], ], [ 'class' => Comment::class, 'alias' => '', 'aliased_properties' => [], 'hide_properties' => [], 'id_properties' => [ 'commentId', ], 'urls' => [ 'self' => 'http://example.com/comments/{commentId}', ], ], [ 'class' => CommentId::class, 'alias' => '', 'aliased_properties' => [], 'hide_properties' => [], 'id_properties' => [ 'commentId', ], 'urls' => [ 'self' => 'http://example.com/comments/{commentId}', ], ], ]; $mapper = new Mapper($mappings);
调用转换器将输出一个使用正确格式的有效XML响应
use NilPortugues\Api\Xml\XmlSerializer; use NilPortugues\Api\Xml\Http\Message\Response; $serializer = new XmlSerializer($mapper); $output = $serializer->serialize($post); //PSR7 Response with headers and content. $response = new Response($output); header( sprintf( 'HTTP/%s %s %s', $response->getProtocolVersion(), $response->getStatusCode(), $response->getReasonPhrase() ) ); foreach($response->getHeaders() as $header => $values) { header(sprintf("%s:%s\n", $header, implode(', ', $values))); } echo $response->getBody();
输出
HTTP/1.1 200 OK
Cache-Control: private, max-age=0, must-revalidate
Content-type: text/xml; charset=utf-8
<?xml version="1.0" encoding="UTF-8"?> <data> <postId><![CDATA[9]]></postId> <headline><![CDATA[Hello World]]></headline> <body><![CDATA[Your first post]]></body> <author> <userId><![CDATA[1]]></userId> <name><![CDATA[Post Author]]></name> </author> <comments> <resource> <commentId><![CDATA[1000]]></commentId> <dates> <created_at><![CDATA[2015-07-18T12:13:00+02:00]]></created_at> <accepted_at><![CDATA[2015-07-19T00:00:00+02:00]]></accepted_at> </dates> <comment><![CDATA[Have no fear, sers, your king is safe.]]></comment> <user> <userId><![CDATA[2]]></userId> <name><![CDATA[Barristan Selmy]]></name> </user> </resource> </comments> <links> <link rel="self" href="http://example.com/posts/9"/> <link rel="comments" href="http://example.com/posts/9/comments"/> </links> </data>
质量
要运行PHPUnit测试,请转到测试目录并运行phpunit。
此库试图遵守PSR-1、PSR-2、PSR-4和PSR-7。
如果您注意到合规性的疏忽,请通过Pull Request发送补丁。
贡献
欢迎对包的贡献!
支持
使用以下方式之一与我联系
- 通过contact@nilportugues.com发送电子邮件给我
- 提交一个问题
作者
许可协议
代码库受MIT许可的许可。