我正在使用PySaml2来实现SAML服务提供程序。
当我接收到有效负载(base64SAMLResponse
(时,我的服务器无法接受它,并返回错误SignatureError('Failed to verify signature')
。
失败的部分是对XMLSec-lib:xmlsec1 --verify --enabled-reference-uris empty,same-doc --enabled-key-data raw-x509-cert --pubkey-cert-pem /path/to/cert.pem --id-attr:ID urn:oasis:names:tc:SAML:2.0:assertion:Assertion --node-id ... --output /path/to/out.xml /path/to/payload.xml
的调用。
然而,我使用的是IdP发给我的证书,我可以在传递给上面调用的cert.pem
中看到,它确实是传递给xmlsec1
的正确证书(与有效载荷本身相同(。
<samlp:Response xmlns:samlp="urn:oasis:names:tc:SAML:2.0:protocol"
xmlns:saml="urn:oasis:names:tc:SAML:2.0:assertion" ID="_d9e74668-c20d-43ea-9952-fb129adec5c2" Version="2.0" IssueInstant="2021-11-02T15:10:46.745Z" Destination="..." InResponseTo="_4606cc1f427fa981e6ffd653ee8d6972fc5ce398c4">
<saml:Issuer>...</saml:Issuer>
<samlp:Status>
<samlp:StatusCode Value="urn:oasis:names:tc:SAML:2.0:status:Success"/>
</samlp:Status>
<saml:Assertion xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xmlns:xs="http://www.w3.org/2001/XMLSchema"
xmlns:saml="urn:oasis:names:tc:SAML:2.0:assertion" ID="_d3f5b2cb-b7d8-4844-9c0f-46e83ba6a7df" Version="2.0" IssueInstant="2021-11-02T15:10:46.745Z">
<saml:Issuer>...</saml:Issuer>
<ds:Signature xmlns:ds="http://www.w3.org/2000/09/xmldsig#">
<ds:SignedInfo>
<ds:CanonicalizationMethod Algorithm="http://www.w3.org/2001/10/xml-exc-c14n#"/>
<ds:SignatureMethod Algorithm="http://www.w3.org/2001/04/xmldsig-more#rsa-sha256"/>
<ds:Reference URI="#_d3f5b2cb-b7d8-4844-9c0f-46e83ba6a7df">
<ds:Transforms>
<ds:Transform Algorithm="http://www.w3.org/2001/10/xml-exc-c14n#"/>
</ds:Transforms>
<ds:DigestMethod Algorithm="http://www.w3.org/2001/04/xmlenc#sha256"/>
<ds:DigestValue>...</ds:DigestValue>
</ds:Reference>
</ds:SignedInfo>
<ds:SignatureValue>...</ds:SignatureValue>
<ds:KeyInfo>
<ds:X509Data>
<ds:X509Certificate>... Here the certificate base64 ...</ds:X509Certificate>
</ds:X509Data>
</ds:KeyInfo>
</ds:Signature>
<saml:Subject>
<saml:NameID Format="urn:oasis:names:tc:SAML:1.1:nameid-format:emailAddress">lui@gmail.com</saml:NameID>
<saml:SubjectConfirmation Method="urn:oasis:names:tc:SAML:2.0:cm:bearer">
<saml:SubjectConfirmationData NotOnOrAfter="2021-11-02T15:15:46.745Z" Recipient="..." InResponseTo="_4606cc1f427fa981e6ffd653ee8d6972fc5ce398c4"/>
</saml:SubjectConfirmation>
</saml:Subject>
<saml:Conditions NotBefore="2021-11-02T15:10:46.745Z" NotOnOrAfter="2021-11-02T15:15:46.745Z">
<saml:AudienceRestriction>
<saml:Audience>...</saml:Audience>
</saml:AudienceRestriction>
</saml:Conditions>
<saml:AttributeStatement>
<saml:Attribute Name="http://schemas.xmlsoap.org/ws/2005/05/identity/claims/emailaddress" NameFormat="urn:oasis:names:tc:SAML:2.0:attrname-format:basic">
<saml:AttributeValue xmlns:xs="http://www.w3.org/2001/XMLSchema"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:type="xs:string">lui@gmail.com</saml:AttributeValue>
</saml:Attribute>
<saml:Attribute Name="http://schemas.xmlsoap.org/ws/2005/05/identity/claims/givenname" NameFormat="urn:oasis:names:tc:SAML:2.0:attrname-format:basic">
<saml:AttributeValue xmlns:xs="http://www.w3.org/2001/XMLSchema"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:type="xs:string">Luis</saml:AttributeValue>
</saml:Attribute>
<saml:Attribute Name="http://schemas.xmlsoap.org/ws/2005/05/identity/claims/surname" NameFormat="urn:oasis:names:tc:SAML:2.0:attrname-format:basic">
<saml:AttributeValue xmlns:xs="http://www.w3.org/2001/XMLSchema"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:type="xs:string">Lui</saml:AttributeValue>
</saml:Attribute>
<saml:Attribute Name="http://schemas.xmlsoap.org/ws/2005/05/identity/claims/name" NameFormat="urn:oasis:names:tc:SAML:2.0:attrname-format:basic">
<saml:AttributeValue xmlns:xs="http://www.w3.org/2001/XMLSchema"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:type="xs:string">Luis Lui</saml:AttributeValue>
</saml:Attribute>
<saml:Attribute Name="http://schemas.xmlsoap.org/ws/2005/05/identity/claims/nameidentifier" NameFormat="urn:oasis:names:tc:SAML:2.0:attrname-format:basic">
<saml:AttributeValue xmlns:xs="http://www.w3.org/2001/XMLSchema"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:type="xs:string">431b0975-c262-4a9c-ab6c-95297efadedb</saml:AttributeValue>
</saml:Attribute>
</saml:AttributeStatement>
</saml:Assertion>
</samlp:Response>
可能出了什么问题?
编辑:下面是收到的base64编码的XML有效载荷:
<samlp:Response xmlns:samlp="urn:oasis:names:tc:SAML:2.0:protocol" xmlns:saml="urn:oasis:names:tc:SAML:2.0:assertion" ID="_b7b20849-b08b-42f2-9ba6-f7ed3c7fdde1" Version="2.0" IssueInstant="2021-11-15T12:45:55.223Z" Destination="https://api.dev.foodles.co/api/auth/saml2/acs/monbuilding/" InResponseTo="_4606cc1f427fa981e6ffd653ee8d6972fc5ce398c4"><saml:Issuer>Witco</saml:Issuer><ds:Signature xmlns:ds="http://www.w3.org/2000/09/xmldsig#"><ds:SignedInfo><ds:CanonicalizationMethod Algorithm="http://www.w3.org/2001/10/xml-exc-c14n#"/><ds:SignatureMethod Algorithm="http://www.w3.org/2001/04/xmldsig-more#rsa-sha256"/><ds:Reference URI="#_b7b20849-b08b-42f2-9ba6-f7ed3c7fdde1"><ds:Transforms><ds:Transform Algorithm="http://www.w3.org/2000/09/xmldsig#enveloped-signature"/><ds:Transform Algorithm="http://www.w3.org/2001/10/xml-exc-c14n#"/></ds:Transforms><ds:DigestMethod Algorithm="http://www.w3.org/2001/04/xmlenc#sha256"/><ds:DigestValue>TEyNVGKNwBxzLK4spLA/N7nwB27e/OGfsvbJYjZjIIM=</ds:DigestValue></ds:Reference></ds:SignedInfo><ds:SignatureValue>Xz4JZKSJ0kg66RhDJyIoT6XojV4CItRnjwy/9xxS/Iypsq5hbhLZJAMXKrNRBOn9bsNp5HKrKqJkJWJyBFu/1S/Q4MxThWNUtBzHuK7xyKv27/eTCYVKXDa/3OaIe3qj+y3NDHAsKR7H/3Sob6vcQ/wvSBn7ehWWOJkFbC3r1ehKjJ1hMfDh0uidTdC8RJnVeminYN6LAdrOAogmtrW9hlEhVpyw2sjPAy5basp7M/nSParXinrNoWI2X+IDY+gUcrj/GBxpHH94Lj0BFZ5hDd47zo9JdMHnd8csslW/9Pl+W9CYVBQGSoAKQcYZT7AiiNFyrjzcDpZ4mhd3GeBQx3lHlc0kjMONbqG0fSTV7O6qqy9pUOBGqfoYg0RcYkl/tGMelPOqsHmCjQN8LMAevZNj3+cdn32aXEhLfr19CUBPNBPqFGsfUSrBYFMd0XaIcarXQoHBu7MOfXCaACQnp7zKN1yYVip0qXfvJK+RnvOXriswWIISJ6mTagTd6bfWQq9p75mi1Yx5EnHig4KY6CKSv1ck83i30RxeCr/4fG99WSMJtJE3GRl0jv3dA8PRDxhNaLf7gu+kur92Cx+Y39MMhq/PM78JI9sIUmq9JIU3Ar7bgwVs5xReFcNKf04148zEkC8ptk8Ek4ribFQBRwSyQFmcq6ErCxNxETYJcfI=</ds:SignatureValue><ds:KeyInfo><ds:X509Data><ds:X509Certificate>MIIFwzCCA6ugAwIBAgIUM/WKU4T2Gg9QDUID2Rq4UYXNyQ4wDQYJKoZIhvcNAQELBQAwcTELMAkGA1UEBhMCRlIxDjAMBgNVBAcMBVBhcmlzMRQwEgYDVQQKDAtNb25CdWlsZGluZzEYMBYGA1UEAwwPbW9uYnVpbGRpbmcuY29tMSIwIAYJKoZIhvcNAQkBFhNkZXZAbW9uYnVpbGRpbmcuY29tMB4XDTIxMDQyMzE1MTM1N1oXDTQxMDQxODE1MTM1N1owcTELMAkGA1UEBhMCRlIxDjAMBgNVBAcMBVBhcmlzMRQwEgYDVQQKDAtNb25CdWlsZGluZzEYMBYGA1UEAwwPbW9uYnVpbGRpbmcuY29tMSIwIAYJKoZIhvcNAQkBFhNkZXZAbW9uYnVpbGRpbmcuY29tMIICIjANBgkqhkiG9w0BAQEFAAOCAg8AMIICCgKCAgEAwxV7LTb2T7kEeRmmDB0iGup4vJ28S/CCcPVBiDsSIlbT5EepRK7NNkVmoh9meZNBTgGRG4BIB0oALU5Iz7fo0cW5b9iFRI7FM2XFH78dYgEEu6Pf7N/IPKsWSUVdtUGbSRhfDIiTaPye2yNk3Io2n1a66NB0H2C+RaJwIY0nUwwLa0BEkVlnxAAmhgzRk72sJeMZykVffD5vc6n/2HnTQATCDC40yt5JFr7YqDS9cMmpX5wCUSbUMGAKdNUOJO3JauzohDqTMk3gp5U++pJ7FKD610BAOtp9A3ZkKjmJDL4hJyNTnuj0B1XAzCOZGzWCVpXGMrCjiOOOc/FiOXOFaR9wxZngjR9Pd8DcpzFzc+kU10rtbwTCnboSH29Po7b8CUxyM0RQ0PVmwEhvNSNY3aTFAWSeQdmVCNj6R+/RWv3ho2993zE6WmQH44anx9S7C0o0QEpEQg322aja//qG9Z2VDKpBQwfPZpPwA7998+gbS6tn+k3CdgSsYsj0co17yeaYzz4r/+vu3uPSJJytuE9yc9D8/slIgVmPW+uhT61LhYkmNlqvD7aJFI0+ZjlSBAKBMV9GJkD6KdS6TuL/VdDMd/otFdvUm9DQxNjXWeHK0G8HqZVRYUCqBHu4em7WuZPpUvCOuE7iKiRufP27KeMfTwOoQohIlaWEe/OJtt8CAwEAAaNTMFEwHQYDVR0OBBYEFE0E8BKcIPOl2SJgZ5Zcvj9SSNbCMB8GA1UdIwQYMBaAFE0E8BKcIPOl2SJgZ5Zcvj9SSNbCMA8GA1UdEwEB/wQFMAMBAf8wDQYJKoZIhvcNAQELBQADggIBADPiNpWKYsElw+YWWx00712tJWLCObRIyhXQFmWo2dZuGFJxLo+4YDkibeeMG62R6FGL1tiPHgfyimV9cXkpsfFD+Jk2L905S/av7bA6nx1MQA3tZLPRoOpTJgl8nIjqnuz/e975yPTy8fFkLhPh2dNBbjEaBLzCVfU5jKhoCuMwx9IOboeH+EjFZ4MxeyHd11PEn9Yz1Hbd8JkBt/CWdGko2akVdTjSf4Y6cR8Tlwpsv2TV0BqCeIrAnWMDSjqSFQ/dlb3/lDmRWe6mVXVCSBNNyCCqIqx8eN5ptP5hvanMTSIBqEBTc2AUQoGlRne5jItAb8t7OEn1bUCFt4R0P0iG4wgkyaFeNKU8yhIBy34fD+3NNAx92M0Dp+8zMKPOVJql3ypmBI3RHIZJppkFZxPitf/l1By1lxqLf0XptcClIZIfMUUrdTPfw59CXOKp4sYkHcAZIBr5BrTkBGmmpx41fl18ZHzqJUpThSVPDYBsxMxFc1kBUCyhVuqi7BwxQyW1tB2RPI0jWQ/mHw5xAkn2fdtfy/FDOvoEawvtlwVqNrDcbnywSp7IiDMXbDNR5RyMhgT1mp4n3Zxm1tdfdZy37IxaESmFGPBVP9WSTlxQMF3FGaOX0LqShiF8utdFy/tI7lZjzHi4Yjb3wPbsQpJ1STrmV6wn0xSIaDtDGXMA</ds:X509Certificate></ds:X509Data></ds:KeyInfo></ds:Signature><samlp:Status><samlp:StatusCode Value="urn:oasis:names:tc:SAML:2.0:status:Success"/></samlp:Status><saml:Assertion xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:xs="http://www.w3.org/2001/XMLSchema" xmlns:saml="urn:oasis:names:tc:SAML:2.0:assertion" ID="_6995235b-b3fc-4285-83a5-53e01771b519" Version="2.0" IssueInstant="2021-11-15T12:45:55.223Z"><saml:Issuer>Witco</saml:Issuer><saml:Subject><saml:NameID Format="urn:oasis:names:tc:SAML:1.1:nameid-format:emailAddress">manager@starkindustriestest.com</saml:NameID><saml:SubjectConfirmation Method="urn:oasis:names:tc:SAML:2.0:cm:bearer"><saml:SubjectConfirmationData NotOnOrAfter="2021-11-15T12:50:55.223Z" Recipient="undefined" InResponseTo="_4606cc1f427fa981e6ffd653ee8d6972fc5ce398c4"/></saml:SubjectConfirmation></saml:Subject><saml:Conditions NotBefore="2021-11-15T12:45:55.223Z" NotOnOrAfter="2021-11-15T12:50:55.223Z"><saml:AudienceRestriction><saml:Audience>undefined</saml:Audience></saml:AudienceRestriction></saml:Conditions><saml:AttributeStatement><saml:Attribute Name="http://schemas.xmlsoap.org/ws/2005/05/identity/claims/emailaddress" NameFormat="urn:oasis:names:tc:SAML:2.0:attrname-format:basic"><saml:AttributeValue xmlns:xs="http://www.w3.org/2001/XMLSchema" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:type="xs:string">manager@starkindustriestest.com</saml:AttributeValue></saml:Attribute><saml:Attribute Name="http://schemas.xmlsoap.org/ws/2005/05/identity/claims/givenname" NameFormat="urn:oasis:names:tc:SAML:2.0:attrname-format:basic"><saml:AttributeValue xmlns:xs="http://www.w3.org/2001/XMLSchema" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:type="xs:string">Anthony</saml:AttributeValue></saml:Attribute><saml:Attribute Name="http://schemas.xmlsoap.org/ws/2005/05/identity/claims/surname" NameFormat="urn:oasis:names:tc:SAML:2.0:attrname-format:basic"><saml:AttributeValue xmlns:xs="http://www.w3.org/2001/XMLSchema" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:type="xs:string">Stark</saml:AttributeValue></saml:Attribute><saml:Attribute Name="http://schemas.xmlsoap.org/ws/2005/05/identity/claims/name" NameFormat="urn:oasis:names:tc:SAML:2.0:attrname-format:basic"><saml:AttributeValue xmlns:xs="http://www.w3.org/2001/XMLSchema" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:type="xs:string">Anthony Stark</saml:AttributeValue></saml:Attribute><saml:Attribute Name="http://schemas.xmlsoap.org/ws/2005/05/identity/claims/nameidentifier" NameFormat="urn:oasis:names:tc:SAML:2.0:attrname-format:basic"><saml:AttributeValue xmlns:xs="http://www.w3.org/2001/XMLSchema" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:type="xs:string">431b0975-c262-4a9c-ab6c-95297efadedb</saml:AttributeValue></saml:Attribute></saml:AttributeStatement></saml:Assertion></samlp:Response>
这很难调试,因为您发布的XML不包括cert、digest,并且已被修改。
XML在发布到网站时可能很难进行检查。修改后是不可能的。请从测试系统生成另一个文件,然后再次发送。Base64在连接之前先对其进行编码也很好。
您也可以尝试--trusted-pem/path/to/cert.pem选项
更新:
使用新的base64
使用https://samltool.io/显示响应是签名的,而不是断言,因此以下操作将起作用:
xmlsec1--verify--受信任的pem证书.pem--启用的引用uri为空,相同的文档--启用的密钥数据raw-x509-cert--pubkey证书pem证书.em--id attr:id响应--输出.xml tmp.xml
这也适用于XML::Sig和https://tools.chilkat.io/xmlDsigVerify.cshtml
我没有使用PySaml2,所以它可能有一个错误,但如果没有,它现在应该使用正确的证书来验证