1

我正在使用 Shibboleth SP 进行 SAML 授权。

最近 IdP 更改了配置,现在需要对 AuthRequest 进行签名。

IdP 的元数据具有以下参数

<md:IDPSSODescriptor protocolSupportEnumeration="urn:oasis:names:tc:SAML:2.0:protocol"
WantAuthnRequestsSigned="true"><md:KeyDescriptor use="signing">

SP 的 shibboleth2.xml 文件有以下标签

<ApplicationDefaults entityID="...."
   REMOTE_USER="eppn persistent-id targeted-id email Email FirstName LastName NameID">

在 IdP 强制执行 AuthRequest 签名后,我们将 shibboleth2.xml 文件更改为如下

<ApplicationDefaults entityID="..."
                         REMOTE_USER="eppn persistent-id targeted-id email 

Email FirstName LastName NameID" 
signing="true" encryption="true">

基本上,我添加了signing="true"and encryption="true"

之后生成的新元数据在标签中具有以下属性

<md:SPSSODescriptor AuthnRequestsSigned="1" 
protocolSupportEnumeration="urn:oasis:names:tc:SAML:2.0:protocol 
urn:oasis:names:tc:SAML:1.1:protocol urn:oasis:names:tc:SAML:1.0:protocol">

较早AuthnRequestsSigned="1"的属性不存在。

在此之后,当我尝试进行身份验证时,它给了我们以下错误,

<samlp:Status><samlp:StatusCode Value="urn:oasis:names:tc:SAML:2.0:status:Responder"/>
        <samlp:StatusMessage>Unable to verify the signature</samlp:StatusMessage>
    </samlp:Status>

问题 1:我需要向 IdP 提供此新元数据吗?问题2:知道为什么会这样吗?问题 3:我需要更改配置中的其他任何内容吗?

PS 在执行 AuthRequest 签名之前,它正在工作,所以我认为配置中没有任何其他问题。

这是示例 AuthRequest

<samlp:AuthnRequest
    AssertionConsumerServiceURL="https://...SP-host.../Shibboleth.sso/SAML2/POST"
    Destination="https://...idp-host.../marrsso/idp/SSO.saml2"
    ID="...some-id..." IssueInstant="2019-01-11T14:13:25Z"
    ProtocolBinding="urn:oasis:names:tc:SAML:2.0:bindings:HTTP-POST" Version="2.0"
    xmlns:samlp="urn:oasis:names:tc:SAML:2.0:protocol">
    <saml:Issuer xmlns:saml="urn:oasis:names:tc:SAML:2.0:assertion">https://...entity-id.../shibboleth</saml:Issuer><samlp:NameIDPolicy AllowCreate="1"/></samlp:AuthnRequest>

我相信签名信息应该作为请求的一部分出现在这里。作为http请求,它作为GET请求,对吗?当我在网络中看到请求时,我可以看到签名作为查询参数 在此处输入图像描述 请求的状态代码是“200”

4

1 回答 1

1

将签名作为查询字符串的一部分发送并不罕见。它就像一个预签名的 URL。

  1. 仅在 SP 上启用“signing=true”不应更改最初生成的密钥。因此,不需要重新发送元数据。如果 SP 的元数据最初是完整导入的,或者他们是否只是添加依赖方和其他基本端点进行集成,请与 IdP 联系,如果不需要请求签名,这可能工作得很好。

  2. 如果 IdP 无法验证签名,那么他们一定是缺少来自 SP 的证书。为了确保在启用签名和加密之前和之后比较两个元数据文件,它们应该匹配(特别是围绕证书),但对于您已经识别的附加属性。否则重新发送元数据。

  3. 在这种情况下,不需要进行其他配置更改。

于 2019-03-11T02:50:43.653 回答