使用 SAML 2.0 作为 SSO 的外部身份提供者的身份服务器 4

Posted

技术标签:

【中文标题】使用 SAML 2.0 作为 SSO 的外部身份提供者的身份服务器 4【英文标题】:Identity server 4 with SAML 2.0 as external identity provider for SSO 【发布时间】:2018-08-10 02:28:58 【问题描述】:

我正在使用身份服务器 4 对我的 ASP.Net Core 解决方案进行身份验证。它与 Facebook、Google 和其他外部身份提供商合作良好。 现在我正在尝试使用来自https://github.com/Sustainsys/Saml2 的 Sustainsys.Saml2 将 SAML 2.0 身份验证添加到身份服务器,并使其作为外部身份提供者工作。 (我们网站的客户希望使用我们的身份服务器使用他们的 SAML 身份提供商登录,就像他们可以通过 Facebook、Google 等登录一样)

而我现在拥有的是

    登录网址 - https://sso.domain.com/saml/idp/profile/redirectorpost/sso

    退出网址 - https://sso.domain.com/saml/idp/profile/post/sls

    CRT 证书 对于我们客户的基于 SAML 的身份提供者。

但是,我在身份服务器 4 startup.cs 文件中找不到描述如何设置 SAML 2.0 配置的文档。 根据可用的示例,我认为配置应如下所示: https://github.com/Sustainsys/Saml2/blob/master/Samples/SampleAspNetCore2ApplicationNETFramework/Startup.cs

services.AddAuthentication()
    .AddSaml2(options => 
        
            options.SPOptions.EntityId = new EntityId("..."); 
            options.IdentityProviders.Add(
                new IdentityProvider(
                        new EntityId("..."), options.SPOptions)
                        
                            LoadMetadata = true,
                        );
            options.SPOptions.ServiceCertificates.Add(new X509Certificate2("..."));
       
    );

示例中有两个网址

    https://localhost:44342/Saml2

    http://localhost:52071/Metadata

这些代表什么

谁能告诉我如何在身份服务器 4 中设置 SAML2 的所有选项?

【问题讨论】:

你搞定了吗?我在同一条船上 【参考方案1】:
    是您的应用程序的实体 ID - 对应于 open id connect 中的客户端 ID。 是上游idp的实体id。

在另一个分支中有一个示例 IdSrv4:https://github.com/Sustainsys/Saml2/tree/netstandard/Samples/SampleIdentityServer4

该示例使用 .NET Core 的预览版,但配置基本相同。

https://github.com/Sustainsys/Saml2/tree/master/Samples 中有工作的 IdentityServer4 示例

【讨论】:

以上是关于使用 SAML 2.0 作为 SSO 的外部身份提供者的身份服务器 4的主要内容,如果未能解决你的问题,请参考以下文章

利用XML签名攻击绕过SAML 2.0 SSO

将 CAS 与外部 SAML 身份提供者集成

使用 SAML 2.0 的自签名证书

配置 ADFS 3.0 / SAML 2.0 以使用 Spring Security 进行 SSO 集成

Spring - 如何使用 SAML 2.0 实现单点登录

是否可以在单个应用程序中拥有 SAML 2.0 身份验证和 JWT 身份验证?