|  support |  documentation |  report a bug |  advanced search |  search howto |  statistics |  random bug |  login
Bug #47531 No way of removing redundant xmlns: declarations
Submitted: 2009-02-28 15:19 UTC Modified: 2017-10-24 06:15 UTC
Avg. Score:3.9 ± 1.1
Reproduced:13 of 13 (100.0%)
Same Version:1 (7.7%)
Same OS:1 (7.7%)
From: sgunderson at bigfoot dot com Assigned:
Status: Open Package: DOM XML related
PHP Version: 5.3CVS-2009-02-28 (snap) OS: Debian
Private report: No CVE-ID: None
Have you experienced this issue?
Rate the importance of this bug to you:

 [2009-02-28 15:19 UTC] sgunderson at bigfoot dot com
There seems to be no good way of manipulating XML namespace declarations at all. In particular, they never get garbage collected in any way, and you cannot remove them manually, so they will stick around forever unless you create a new one. My typical use case is shown in the reproduce code below (although the element will typically have child elements).

Since 5.3 (bug #38949) it seems I can getAttribute() the xmlns element, but still not remove it it any reasonable way (and it should really just disappear by itself; it does in other languages).

Reproduce code:

$doc = new DOMDocument;
$doc->loadXML('<html xmlns="something"><element xmlns:ns="whatever" ns:foo="bar" /></html>');
$root = $doc->documentElement;
$elem = $root->firstChild;
print $doc->saveXML();


Expected result:
<?xml version="1.0"?>
<html xmlns="something"><element/></html>

Actual result:
<?xml version="1.0"?>
<html xmlns="something"><element xmlns:ns="whatever"/></html>


Add a Patch

Pull Requests

Add a Pull Request


AllCommentsChangesGit/SVN commitsRelated reports
 [2009-06-14 19:06 UTC] robin2009 at altruists dot org
You can run DOMs through an XSLT identity transform to strip redundant namespaces, since this removes (what it deems to be) unused namespaces (i.e. namespaces which don't appear as elements or attributes).

This method is not only slow for large DOMs, if you're working with XSDs or XSLTs, both of which use namespaces inside attribute values, it would need modification, since XSLT strips them.
 [2010-06-20 21:31 UTC]
-Status: Open +Status: Assigned -Assigned To: +Assigned To: rrichards
 [2013-06-02 16:30 UTC] ekuratopen at spamavert dot com
> Since 5.3 (bug #38949) it seems I can getAttribute() the xmlns element, but still not remove it it any reasonable way

you may remove the namespace attribute by using
$e = $doc->documentElement;
$e->removeAttributeNS($e->getAttributeNode('xmlns')->nodeValue, '');
so you will not need to do registerNamespace() in DOMXPath if DOM has it for example
 [2017-10-24 06:15 UTC]
-Status: Assigned +Status: Open -Assigned To: rrichards +Assigned To:
PHP Copyright © 2001-2023 The PHP Group
All rights reserved.
Last updated: Tue Jan 31 12:05:53 2023 UTC