mmusaib/xml-builder 问题修复 & 功能扩展

解决BUG、新增功能、兼容多环境部署,快速响应你的开发需求

邮箱:yvsm@zunyunkeji.com | QQ:316430983 | 微信:yvsm316

mmusaib/xml-builder

最新稳定版本:v1.0.1

Composer 安装命令:

composer require mmusaib/xml-builder

包简介

A lightweight, fluent XML builder utility for PHP using native DOMDocument

README 文档

README

A lightweight, fluent XML builder built on top of PHP's DOMDocument.

Installation

composer require mmusaib/xml-builder

Usage

use mmusaib\XmlBuilder\XmlBuilder;

$xml = new XmlBuilder('products');

$product = $xml->addElementToRoot('product');
$xml->addAttributes($product, [
    'id' => 101,
    'type' => 'digital'
]);

$xml->addElement($product, 'name', 'Premium Course');
$xml->addCDATAElement(
    $product,
    'description',
    '<strong>High quality content</strong>'
);

echo $xml->getXml();

🚀 Streaming Large XML Files (Chunk-Safe Mode)

When generating very large XML files (hundreds of thousands or millions of nodes), keeping everything in memory using DOMDocument can cause memory exhaustion. XmlBuilder supports streaming mode, allowing you to:

  • Keep the root element constant
  • Append children chunk by chunk
  • Write directly to a file
  • Keep memory usage extremely low

Start Streaming

$xml = new XmlBuilder('products');
$xml->startStream('products.xml');

This writes:

<?xml version="1.0" encoding="UTF-8"?>
<products>

Append Nodes Per Chunk

foreach ($chunks as $chunk) {
    foreach ($chunk as $item) {
        $product = $xml->addElementToRoot('product');

        $xml->addElement($product, 'name', $item['name']);
        $xml->addElement($product, 'price', $item['price']);

        $xml->appendToStream($product);   // Writes & frees memory
    }
}

Each call:

  • Writes ... to file
  • Removes it from memory immediately

Finish Streaming

$xml->endStream();

This closes the root element:

</products>

✅ Why Use Streaming Mode?

Problem Streaming Solves
Millions of records
Memory exhaustion
Chunked DB processing
Long-running jobs

Features

  • Fluent XML creation
  • CDATA support
  • Attribute helpers
  • Encoding-safe
  • Pretty or compact output
  • PSR-4 autoloading

License

MIT

统计信息

  • 总下载量: 19
  • 月度下载量: 0
  • 日度下载量: 0
  • 收藏数: 1
  • 点击次数: 5
  • 依赖项目数: 0
  • 推荐数: 0

GitHub 信息

  • Stars: 1
  • Watchers: 0
  • Forks: 0
  • 开发语言: PHP

其他信息

  • 授权协议: MIT
  • 更新时间: 2026-01-07