# A wrapper of the XML parser and builder
Split from the wechatpay-php project for general usages.
[](https://github.com/TheNorthMemory/xml/actions)
[](https://packagist.org/packages/thenorthmemory/xml)
[](https://packagist.org/packages/thenorthmemory/xml)
[](https://packagist.org/packages/thenorthmemory/xml)
[](https://packagist.org/packages/thenorthmemory/xml)
[](https://packagist.org/packages/thenorthmemory/xml)
## Install
```shell
composer require thenorthmemory/xml
```
## Usage
```php
use TheNorthMemory\Xml\Transformer;
$array = Transformer::toArray('world');
// print_r($array);
// Array
// (
// [hello] => world
// )
$xml = Transformer::toXml($array);
// print_r($xml);
// world
$xml = <<
t146d70eb241c44c63b6efc1cc93ccfc5d
t12a74d11687d444deba8a6cc52051ac27
TencentCOSRequest;
$array = Transformer::toArray($xml);
// Array
// (
// [Operation] => Array
// (
// [WatermarkTemplateId] => Array
// (
// [0] => t146d70eb241c44c63b6efc1cc93ccfc5d
// [1] => t12a74d11687d444deba8a6cc52051ac27
// )
// )
// )
$xml1 = Transformer::toXml($array, true, true, 'Request');
// print_r($xml1);
//
//
//
// - t146d70eb241c44c63b6efc1cc93ccfc5d
// - t12a74d11687d444deba8a6cc52051ac27
//
//
//
$array['Operation']['WatermarkTemplateId'] = Transformer::wrap($array['Operation']['WatermarkTemplateId'], true, 'WatermarkTemplateId');
$xml2 = Transformer::toXml($array, true, true, 'Request');
// print_r($xml2);
//
//
// t146d70eb241c44c63b6efc1cc93ccfc5d
// t12a74d11687d444deba8a6cc52051ac27
//
//
```
## API
**`Transformer::toArray(string $xml = '')`**
Parse the XML `string` to `array`.
**`Transformer::sanitize(string $xml = '')`**
Sanitize the XML `string` in the [XML1.0 20081126 Character Range](https://www.w3.org/TR/2008/REC-xml-20081126/#charsets).
**`Transformer::toXml(array $data, bool $headless = true, bool $indent = false, string $root = 'xml', string $item = 'item'): string`**
Build the data `array` to XML `string`.
**`Transformer::wrap(array $data, bool $wrapped = false, string $label = 'item'): LabeledArrayIterator`**
Wrap the `array` data with a `label` and `wrapped` flag.
## License
[Apache-2.0 License](LICENSE)