【问题标题】:SAML failed to verify signatureSAML 未能验证签名
【发布时间】:2021-12-18 03:19:06
【问题描述】:

我正在使用PySaml2 来实现一个 SAML 服务提供者。

当我收到有效负载 (base64 SAMLResponse) 时,我的服务器无法接受它并出现错误 SignatureError('Failed to verify signature')

失败的部分是对 XMLSec 库的调用: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>

【问题讨论】:

    标签: python xml saml saml-2.0 xml-signature


    【解决方案1】:

    这很难调试,因为您发布的 XML 不包含证书、摘要并且已修改。

    XML 在发布到网站时可能很难检查。修改后是不可能的。请从测试系统生成另一个文件并再次发送。在附加之前先对其进行 Base64 编码也很好。

    您也可以尝试 --trusted-pem /path/to/cert.pem 选项

    更新:

    使用新的 base64

    使用https://samltool.io/ 表明响应已签名而不是断言,因此以下将起作用:

    xmlsec1 --verify --trusted-pem cert.pem --enabled-reference-uris empty,same-doc --enabled-key-data raw-x509-cert --pubkey-cert-pem cert.pem - -id-attr:ID 响应 --output out.xml tmp.xml

    这也适用于 XML::Sig 和 https://tools.chilkat.io/xmlDsigVerify.cshtml

    我没有使用 PySaml2,所以它可能有错误,但如果没有,它现在应该使用正确的证书来验证

    【讨论】:

    • 对。我将 base64 XML 附加到我的帖子中。
    • 感谢我使用tools.chilkat.io/xmlDsigVerify.cshtml 和 XML::Sig 检查的 base64,而且摘要和签名都不匹配。您是否可以在浏览器中安装 Saml 解码器。从中获取base64,以防浏览器收到它后修改它
    • 我在我的帖子中更新了下面的 base 64 为一个新的,它是服务器接收到的实际有效负载。使用这个工具dotnetsnip.com/online-saml-signature-validator-tool,它被接受(前一个不是),但它仍然被你的工具和我的库拒绝。你知道这可能是什么原因吗?
    • 这似乎可以用 XML::Sig 验证:参考摘要:TEyNVGKNwBxzLK4spLA/N7nwB27e/OGfsvbJYjZjIIM= 计算摘要:TEyNVGKNwBxzLK4spLA/N7nwB27e/OGfsvbJYjZjIIM= xmlsec 不验证它所以我晚上 - 可能我为 xmlsec1 使用了不正确的选项
    • 这行得通 - 您试图验证未签名的断言的签名。响应已签名:xmlsec1 --verify --trusted-pem cert.pem --enabled-reference-uris empty,same-doc --pubkey-cert-pem cert.pem --id-attr:ID Response --output out.xml tm p.xml
    猜你喜欢
    • 1970-01-01
    • 2016-01-14
    • 2013-10-28
    • 2014-02-08
    • 2016-07-09
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多