PHP Conference Japan 2024

SimpleXMLElement::__construct

(PHP 5, PHP 7, PHP 8)

SimpleXMLElement::__construct 创建一个新的 SimpleXMLElement 对象

描述

public SimpleXMLElement::__construct(
    字符串 $data,
    整数 $options = 0,
    布尔值 $dataIsURL = false,
    字符串 $namespaceOrPrefix = "",
    布尔值 $isPrefix = false
)

创建一个新的 SimpleXMLElement 对象。

参数

data

一个格式良好的 XML 字符串,或者如果 dataIsURLtrue,则为 XML 文档的路径或 URL。

options

可选地用于指定 其他 Libxml 参数,这些参数会影响 XML 文档的读取。影响 XML 文档输出的选项(例如 LIBXML_NOEMPTYTAG)会被静默忽略。

注意:

可能需要传递 LIBXML_PARSEHUGE 才能处理深度嵌套的 XML 或非常大的文本节点。

dataIsURL

默认情况下,dataIsURLfalse。使用 true 指定 data 是 XML 文档的路径或 URL,而不是 字符串 数据。

namespaceOrPrefix

命名空间前缀或 URI。

isPrefix

如果 namespaceOrPrefix 是前缀,则为 true,如果是 URI,则为 false;默认为 false

错误/异常

对 XML 数据中发现的每个错误都会产生 E_WARNING 错误消息,并且如果 XML 数据无法解析,则还会抛出一个 Exception

提示

使用 libxml_use_internal_errors() 抑制所有 XML 错误,并使用 libxml_get_errors() 之后迭代它们。

示例

注意:

列出的示例可能包括 example.php,它指的是 基本用法 指南第一个示例中找到的 XML 字符串。

示例 #1 创建一个 SimpleXMLElement 对象

<?php

include 'example.php';

$sxe = new SimpleXMLElement($xmlstr);
echo
$sxe->movie[0]->title;

?>

以上示例将输出

PHP: Behind the Parser

示例 #2 从 URL 创建一个 SimpleXMLElement 对象

<?php

$sxe
= new SimpleXMLElement('http://example.org/document.xml', 0, true);
echo
$sxe->asXML();

?>

参见

添加注释

用户贡献的注释 7 个注释

rowan dot collins at gmail dot com
7 年前
手册并没有真正解释 $ns 参数(以及附带的 $is_prefix)的用途。

它们的作用类似于 ->children() 方法:它们将返回对象的上下文设置为该命名空间,以便通过 ->elementName 和 ['attributeName'] 访问该命名空间中的元素和属性。

特别是,它们*不会*更改文档中存在的命名空间。

参见此示例

<?php
// 此 XML 包含两个名为 <child> 的元素
// 一个位于命名空间 http://example.com, 中,本地前缀为 'ws'
// 另一个没有命名空间(没有前缀,也没有声明默认命名空间)
$xml = '<ws:example xmlns:ws="http://example.com"><child>Not in namespace</child><ws:child>In example namespace</ws:child></ws:example>';

$sx0 = new SimpleXMLElement($xml, 0, false);
$sx1 = new SimpleXMLElement($xml, 0, false, 'http://example.com');
$sx2 = new SimpleXMLElement($xml, 0, false, 'ws', true);

echo
"
Without:
{$sx0->child}
By namespace:
{$sx1->child}
By prefix:
{$sx2->child}
"
;
?>

输出

Without: Not in namespace
By namespace: In example namespace
By prefix: In example namespace
tudor at culise dot net
17 年前
此类是可扩展的,但遗憾的是其构造函数无法被覆盖(PHP 表示它是一个 final 方法)。因此,应该使用委托原则而不是扩展来包装该类。
ahmad dot mayahi at gmail dot com
8 年前
您将无法加载没有根元素的 XML 文件

//这将抛出异常
$xml = new SimpleXMLElement('<?xml version="1.0" encoding="UTF-8"?>', null, false);

//这是解决方案
$xml = new SimpleXMLElement('<?xml version="1.0" encoding="UTF-8"?><root></root>', null, false);
info at ensostudio dot ru
3 年前
扩展 SimpleXMLElement
<?php
XmlElement 扩展 \SimpleXMLElement
{
public static function
factory(string $root): self
{
return new static(
'<?xml version="1.0" encoding="UTF-8"?><'.$root.'/>', LIBXML_BIGLINES | LIBXML_COMPACT);
}

/**
* @param iterable $attributes 元素属性的数组,以名称/值对的形式
* @return $this
*/
public function addAttributes(iterable $attributes)
{
foreach (
$attributes as $name => $value) {
$this->addAttribute($name, $value);
}

return
$this;
}

/**
* @param string $name 子元素名称
* @param string|array|null $valueOrAttributes 子元素值或属性数组
* @param string|null $namespace 子元素命名空间
* @return static|null
*/
public function addChild($name, $valueOrAttributes = null, $namespace = null)
{
if (
is_array($valueOrAttributes)) {
$child = parent::addChild($name, null, $namespace);
foreach (
$valueOrAttributes as $name => $value) {
$child->addAttribute($name, $value);
}
} else {
$child = parent::addChild($name, $valueOrAttributes, $namespace);
}

return
$child;
}

/**
* @param iterable $childs 子元素数组,以名称/值(或属性)对的形式
* @return $this
*/
public function addChilds(iterable $childs)
{
foreach (
$childs as $name => $value) {
$this->addChild($name, $value);
}

return
$this;
}
}
?>
bertolini dot cedric at me dot com
10 年前
值得注意的是,SimpleXmlElement::__construct 的行为与 simplexml_load_string 不完全相同,在处理 libxml_use_internal_errors() 方面。

在我的例子中,

<?php
libxml_use_internal_errors
(true);
new
\SimpleXmlElement($data);
?>

仍然抛出错误。但是,一旦我切换到

<?php
libxml_use_internal_errors
(true);
simplexml_load_string($data);
?>

一切正常,并且我停止收到错误。
kumarldh at gmail dot com
13 年前
使用 libxml_use_internal_errors() 可能会抑制错误,但异常仍然需要适当的处理。我使用了以下代码片段。

<?php
libxml_use_internal_errors
(true);
try{
$xmlToObject = new SimpleXMLElement($notSoWellFormedXML);
} catch (
Exception $e){
echo
'请稍后再试...';
exit();
}
?>
uramihsayibok, gmail, com
15 年前
当我填写错误报告时,我意识到为什么(这里只是猜测)构造函数是 final 的:以便像 simplexml_load_file 和 simplexml_load_string 这样的函数可以工作。我想 PHP 化的代码看起来像

<?php

function simplexml_load_file($filename, $class_name = "SimpleXMLElement", $options = 0, $ns = "", $is_prefix = false) {
return new
$class_name($filename, $options, true, $ns, $is_prefix);
}

?>

如果我们要使用不同的 $class_name 并更改构造函数的定义,这些函数将无法工作。

没有简单、合理的解决方案可以保留 simplexml_load_file 和 simplexml_load_string。
To Top