注意:未定义 属性:DOMDocument::$documentElement

Notice: Undefined property: DOMDocument::$documentElement

我最近重新打开了一个旧的(1 年)Symfony 项目,我在每个页面上都有一个错误(我不记得一年前有过这个问题):

[exception] 500 | Internal Server Error | Symfony\Component\Config\Exception\FileLoaderLoadException
/var/www/[...]/wdt.xml

ContextErrorException: Notice: Undefined property: DOMDocument::$documentElement

如果我清除缓存,错误就会消失,但是一旦我编辑并保存文件,错误就会再次出现。 该项目使用的是 Symfony 2.8,我已更新到 Symfony 3.2,但并没有解决问题。

我认为问题与 wdt.xml 文件无关,我认为这可能与我的笔记本电脑配置有关。

我真的不知道从哪里开始调查所以欢迎任何建议!

编辑 1 :
实际上,我几天前创建的另一个项目也遇到了同样的问题。该项目不使用任何额外的包,我只是创建了 5 个实体并生成了 MySQL 数据库。

编辑 2 :
经过更多研究,我决定创建一个新的 Ubuntu VM 并测试一个新的 Symfony 项目,它运行得非常完美,所以它一定与我笔记本电脑上的配置有关。

编辑 3 :
经过更多测试后,这是我添加 print_r($dom) 时得到的结果;在文件 XmlUtils.php (vendor/symfony/symfony/src/Symfony/Component/Config/Util/XmlUtils.php) 第 59 行:

Ubuntu 虚拟机(无错误):

DOMDocument Object ( [doctype] => [implementation] => (object value omitted) [documentElement] => (object value omitted) [actualEncoding] => [encoding] => [xmlEncoding] => [standalone] => 1 [xmlStandalone] => 1 [version] => 1.0 [xmlVersion] => 1.0 [strictErrorChecking] => 1 [documentURI] => /var/www/my_project/web/ [config] => [formatOutput] => [validateOnParse] => 1 [resolveExternals] => [preserveWhiteSpace] => 1 [recover] => [substituteEntities] => [nodeName] => #document [nodeValue] => [nodeType] => 9 [parentNode] => [childNodes] => (object value omitted) [firstChild] => (object value omitted) [lastChild] => (object value omitted) [previousSibling] => [attributes] => [ownerDocument] => [namespaceURI] => [prefix] => [localName] => [baseURI] => /var/www/my_project/web/ [textContent] => %kernel.charset% %kernel.default_locale% )

Ubuntu 笔记本电脑(错误):

DOMDocument Object ( [validateOnParse] => 1 [nodeName] => #document [nodeValue] => [nodeType] => 9 [parentNode] => [childNodes] => (object value omitted) [firstChild] => (object value omitted) [lastChild] => (object value omitted) [previousSibling] => [attributes] => [ownerDocument] => [namespaceURI] => [prefix] => [localName] => [baseURI] => /var/www/lab/symfony/booklib/web/ [textContent] => %kernel.charset% %kernel.default_locale% )

我的笔记本电脑上好像缺少一些信息...

所以基本上,函数 $dom->loadXML 在我的笔记本电脑环境和 VM 内部 return 不具有相同的值...知道为什么吗?

您好,我也遇到了这个问题。我的解决方法是:

composer update

希望对某些人有所帮助。

我终于通过卸载/重新安装解决了问题php7。 我不知道为什么我会遇到这个问题...

感谢@pjehan。我有同样的问题,我已经失去了一天。最后,我确实喜欢上了你,并且成功了。 只需指定一件事:unistall PHP 7.0.x 和 PHP 7.1.3 安装程序(PHP 7 的稳定版本)。版本PHP 7 稳定的link:http://php.net/downloads.php 非常感谢,@pjehan,你救了我的命 :D

我安装了 Ubuntu 16.04 php7.0.15,我通过删除 php-xdebug 扩展名修复了错误。

sudo apt-get purge php-xdebug

这很奇怪,但请尝试更改 php 配置中的 php 扩展加载顺序。这解决了我的问题...在列表

的上方或下方移动 dom 扩展名

我通过禁用 cli 的 xdebug 解决了这个问题

在我的例子中,错误是由在两个地方加载的 dom.so 扩展触发的。删除一个解决了问题。

在我的例子中,dom 扩展被启用了两次。曾经在 dom.ini 中,也在 php.ini 中。我从 php.ini 中删除了 extension=dom.so 条目并重新加载了 apache2 网络服务器。

这可能是相关的: https://getcomposer.org/doc/articles/troubleshooting.md#xdebug-impact-on-composer

TLDR:如果您将 xdebug 与 composer 一起使用,请使用 COMPOSER_ALLOW_XDEBUG=1