Shibboleth SP 忽略 MetadataProvider

标签 shibboleth shibboleth-sp

我第一次尝试运行 Shibboleth SP,但我立即遇到了一个问题,我已经三天不明白了:/

我使用 docker 镜像 unicon/shibboleth-sp作为开始的基础。 到目前为止,我刚刚修改了 shibboleth2.xml在两个地方。我写了一个特定的 IdP entityID进入<SSO>部分并添加了一个 <MetadataProvider>指向包含 IdP 元数据的外部 XML 文件。

恕我直言,当我尝试访问 SP 上 protected URL 时,这应该足以重定向到 IdP。但是相反,我得到了一个 Shibb-Exception No MetadataProvider available .

这些是我对 shibboleth2.xml 所做的更改:

<ApplicationDefaults entityID="https://sp.example.org/shibboleth" ... >
    ...
    <Sessions ... >
        ...
        <!--
        Configures SSO for a default IdP. To properly allow for >1 IdP, remove
        entityID property and adjust discoveryURL to point to discovery service.
        You can also override entityID on /Login query string, or in RequestMap/htaccess.
        -->
        <SSO entityID="https://testidp.aai.dfn.de/idp/shibboleth"
            discoveryProtocol="SAMLDS" discoveryURL="http://www.aai.dfn.de/DS/WAYF">
            SAML2
        </SSO>
        ...
    </Sessions>
    ...
    <MetadataProvider type="XML" id="dfn-aai-test-metadata"
        url="http://www.aai.dfn.de/fileadmin/metadata/dfn-aai-test-metadata.xml"
        backingFilePath="federation-dockermeta-metadata.xml" maxRefreshDelay="3600">
        <MetadataFilter type="RequireValidUntil" maxValidityInterval="2419200"/>
        <MetadataFilter type="Signature" certificate="/etc/ssl/aai/dfn-aai.g2.pem" verifyBackup="false"/>
    </MetadataProvider>
    ...
</ApplicationDefaults>

经过几天的调试,我非常确定 SP 正确解析了 <MetadataProvider>标签,但似乎完全忽略了它。 将日志级别设置为 DEBUG显示 MetadataProvider 已被解析(其 XML 结构在日志输出中可见),但它不会尝试访问 URL。甚至没有对 www.aai.dfn.de 的 DNS 请求它也不会尝试访问 URL。此外,日志中没有错误。甚至没有迹象表明它试图在日志中加载外部元数据。我在日志文件中遇到的第一个也是唯一一个错误是 No MetadataProvider available在尝试访问 protected 资源之后。

我以前从未设置过 Shibboleth SP(因为每个人都告诉我这是 PITA)。我不确定这是 Shibboleth SP 还是 docker 镜像的问题。很可能我就是问题所在,我只是遗漏了一些非常明显的东西......

我需要帮助:)

我使用的完整代码可以在这里找到: https://gitlab.com/xsrf/shibb-sp/tree/5380f4550ac1a5ffb47d96138d837f1cf6acdb60

最佳答案

当我看到这个时,通常是权限问题...即运行 shibd 进程的用户无权访问元数据文件(或者在这种情况下更可能是权限问题用于验证的文件)。我认为仅在 Dockerfile 中执行 docker add 是不够的,因为 shibd 无法读取 /etc/ssl/aai/

我必须提取您的存储库并亲自尝试才能弄清楚具体要做什么,但似乎可以快速捏造将证书放入 /etc/shibboleth 中。 shibd 可以读取该目录。

编辑:除了权限问题之外,它似乎无法下载该元数据...我通过添加

更正了权限问题
RUN chown -R shibd:shibd /etc/shibboleth/
RUN chown -R shibd:shibd /var/cache/shibboleth/

到您的 Dockerfile。

现在我在尝试测试配置时看到这个错误:

root@ac4861a1faae shibboleth]# /usr/sbin/shibd -t
2019-10-03 16:51:39 CRIT XMLTooling.Config : libcurl lacks OpenSSL-specific options, this will greatly limit functionality
2019-10-03 16:51:39 WARN Shibboleth.Application : insecure cookieProps setting, set to "https" for SSL/TLS-only usage
2019-10-03 16:51:39 WARN Shibboleth.Application : handlerSSL should be enabled for SSL/TLS-enabled web sites
2019-10-03 16:51:39 ERROR XMLTooling.libcurl.InputStream [dfn-aai-test-metadata]: error while fetching http://www.aai.dfn.de/fileadmin/metadata/dfn-aai-test-metadata.xml: (22) The requested URL returned error: 404 Not Found
2019-10-03 16:51:39 ERROR XMLTooling.ParserPool [dfn-aai-test-metadata]: fatal error on line 0, column 0, message: internal error in NetAccessor
2019-10-03 16:51:39 ERROR OpenSAML.MetadataProvider.XML [dfn-aai-test-metadata]: error while loading resource (http://www.aai.dfn.de/fileadmin/metadata/dfn-aai-test-metadata.xml): XML error(s) during parsing, check log for specifics
2019-10-03 16:51:39 WARN OpenSAML.MetadataProvider.XML [dfn-aai-test-metadata]: adjusted reload interval to 600 seconds
2019-10-03 16:51:39 WARN OpenSAML.MetadataProvider.XML [dfn-aai-test-metadata]: trying backup file, exception loading remote resource: XML error(s) during parsing, check log for specifics
2019-10-03 16:51:39 ERROR XMLTooling.ParserPool [dfn-aai-test-metadata]: fatal error on line 0, column 0, message: unable to open primary document entity '/var/cache/shibboleth/federation-dockermeta-metadata.xml'
2019-10-03 16:51:39 ERROR OpenSAML.MetadataProvider.XML [dfn-aai-test-metadata]: error while loading resource (/var/cache/shibboleth/federation-dockermeta-metadata.xml): XML error(s) during parsing, check log for specifics
2019-10-03 16:51:39 CRIT Shibboleth.Application : error initializing MetadataProvider: XML error(s) during parsing, check log for specifics
overall configuration is loadable, check console or log for non-fatal problems

果然……尝试从 docker 容器中 CURL 那个 URL 失败了:

[root@ac4861a1faae shibboleth]# curl http://www.aai.dfn.de/fileadmin/metadata/dfn-aai-test-metadata.xml
<!DOCTYPE HTML PUBLIC "-//IETF//DTD HTML 2.0//EN">
<html><head>
<title>404 Not Found</title>
</head><body>
<h1>Not Found</h1>
<p>The requested URL was not found on this server.</p>
</body></html>

即使它在我的本地机器上成功了。使用静态文件有效,请参阅:https://i.imgur.com/gXxC7z9.png对于实际上未与该 IdP 集成的 SP,这基本上是我希望看到的。

所以,我认为问题出在您的 docker 网络中。

编辑#2:不,只是杀死了你的虚拟网络服务器,我不知何故没有连接它正在运行并且它工作得很好。就像我说的,这是一个权限问题。将这两行 RUN 添加到 Dockerfile 的末尾,它应该可以工作。

关于Shibboleth SP 忽略 MetadataProvider,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/58218557/

相关文章:

java - 单一注销不适用于 Shibboleth IdP

java - 如何从 SAML 响应中识别用户?

single-sign-on - 我是否应该要求 IdP 签署 SAML2 SSO 响应?

active-directory - Web 应用程序的单点登录

angular - Angular 单页应用程序 (SPA) 的 Shibboleth 身份验证

spring - Java - Spring security、Shibboleth (apache) 和 onelogin

azure - Shibboleth SP 注销不会重定向到我正确的服务器 URL