XML:
<?xml version="1.0"?>
<saml:Assertion xmlns:saml="urn:oasis:names:tc:SAML:2.0:assertion" ID="_9069a2d7-491f-49ca-a13f-96c5bad39b14" IssueInstant="2010-04-06T16:27:34Z" Version="2.0">
<saml:Issuer Format="urn:oasis:names:tc:SAML:2.0:nameid-format:entity">https://ssl.perquisite.net/memberweb/federation</saml:Issuer>
<Signature xmlns="http://www.w3.org/2000/09/xmldsig#">
<SignedInfo>
<CanonicalizationMethod Algorithm="http://www.w3.org/2001/10/xml-exc-c14n#"/>
<SignatureMethod Algorithm="http://www.w3.org/2000/09/xmldsig#rsa-sha1"/>
<Reference URI="#_9069a2d7-491f-49ca-a13f-96c5bad39b14">
<Transforms>
<Transform Algorithm="http://www.w3.org/2000/09/xmldsig#enveloped-signature"/>
<Transform Algorithm="http://www.w3.org/2001/10/xml-exc-c14n#">
<InclusiveNamespaces xmlns="http://www.w3.org/2001/10/xml-exc-c14n#" PrefixList="#default saml ds xs xsi"/>
</Transform>
</Transforms>
<DigestMethod Algorithm="http://www.w3.org/2000/09/xmldsig#sha1"/>
<DigestValue>QpoCI6jZFhQi+PuYM6UaFBL9KEU=</DigestValue>
</Reference>
</SignedInfo>
<SignatureValue>X8X6qSUDKa3h3+/girXCeOVxo8=</SignatureValue>
<KeyInfo>
<X509Data>
<X509Certificate>MIIB2...CieOpEo35g==</X509Certificate>
</X509Data>
</KeyInfo>
</Signature>
<saml:Subject>
<saml:NameID Format="urn:oasis:names:tc:SAML:2.0:nameid-format:transient">654d2065-6eed-401f-bf6d-a181117a5fb8</saml:NameID>
</saml:Subject>
<saml:Conditions NotBefore="2010-04-06T16:27:04Z" NotOnOrAfter="2010-04-06T16:28:04Z"/>
<saml:AuthnStatement AuthnInstant="2010-04-06T16:27:34Z">
<saml:AuthnContext>
<saml:AuthnContextClassRef>urn:oasis:names:tc:SAML:2.0:ac:classes:X509</saml:AuthnContextClassRef>
</saml:AuthnContext>
</saml:AuthnStatement>
</saml:Assertion>
コード:
$xml
上記のxmlに設定されています。
$sxml = new SimpleXMLElement($xml);
$sxml->registerXPathNamespace('saml', 'urn:oasis:names:tc:SAML:2.0:assertion');
$sxml->registerXPathNamespace('sig', 'http://www.w3.org/2000/09/xmldsig#');
$signodes = $sxml->xpath('/saml:Assertion/sig:Signature');
この時点で、sig:Signature ノードとすべての子ノードを XML から削除します。私はもう試した:
$node = dom_import_simplexml($signodes[0]);
$node->parentNode->removeChild($node);
と:
foreach($signodes as $item) {
$node = dom_import_simplexml($item);
$node->parentNode->removeChild($node);
}
と:
unset($signodes);
と:
foreach($signodes as $node) {
unset($node);
}
次に、次の方法で XML を取得します。
$Canonical = $sxml->asXML();
上記のすべては、結果の XML に影響を与えないようです (ただし、エラーも発生しません)。
誰にも理由の手がかりがありますか?