当前位置: 首页 > 知识库问答 >
问题:

SAML SSO它是如何工作的?

江华容
2023-03-14

假设我们有一个名为托管在tomcat上的服务提供商应用程序,用户单击指向SP a的链接。SP a没有看到提供的令牌,因此它会将用户重定向到IdP进行身份验证(通过某种方式提供SAML Authn请求)。然后,IdP将用户重定向到提供凭据的某个公共登录页面,假设这些凭据正确,IdP将创建一个SAML响应,其中包含一个令牌和一些关于主题的断言,并将其发送回SP a。SP a看到了这一点,并允许用户访问应用程序。太棒了

不过我有几个问题

  1. 授权请求/响应是如何发送的,我知道有一个重定向绑定和一个POST绑定,其中SAML响应和请求被编码为查询参数,或者在POST绑定的情况下作为XHTML表单发送。但我不确定在哪里使用?
  2. 服务提供商是提供服务的东西,例如Office 365或Salesforce。每个都是单独的服务提供商吗?我在看视频时问,那个人说服务提供商是托管这些服务的东西,所以我不确定这里的正确答案?
  3. 令牌如何存储在客户端?例如,我现在针对SP A进行了身份验证,然后用户尝试从同一台机器/浏览器窗口使用SP B,SP B和IdP如何知道用户已经通过身份验证,因此不需要重新验证。即它的SSO方面。
  4. SP B是否需要托管在同一个tomcat实例上才能工作?

共有2个答案

逄兴昌
2023-03-14

根据我自己的经验:

>

  • 您可以根据idp和sp支持的内容选择自己的示例绑定(重定向或post)。此绑定类型将用于第一步(SP-

    Office 365和Salesforce。com是云服务,对吗?让我们开始365办公吧。这意味着除了“最终用户”服务(如Word、Excel)之外,还有一些平台通用的技术SSO服务。可以将其视为较低(或技术)的服务层,我认为这是您所说的意思。

    SAML令牌由SP应用程序存储在浏览器中,隐藏在网页、cookie或web存储中。这取决于SP的实现方式。

    SAML响应可以由每个SP基于共享私钥进行验证,因此它将使用此密钥解密令牌,并且能够在没有IdP重定向的帮助下授予用户。

  • 拓拔弘厚
    2023-03-14

    我花了大量时间让SSO为我工作。最有用的文档是本规范

    以下答案基于这一经验:

    1. 重定向或Post绑定的使用取决于相应的HTTP请求标头。建议使用Post绑定,因为它不意味着对传输的数据量的限制。
    2. 在这种情况下,服务提供者是客户端请求的任何内容。他们中可能有许多人参与同一个SSO方案。
    3. 服务提供商必须了解SSO,其中包括处理身份验证响应数据。通常您不必实现协议-您的SP可以使用现成的框架。
    4. 服务提供商可能驻留在不同的服务器上。
     类似资料:
    • 为了减少内核或跨进程内存泄漏(Spectre攻击),Linux内核1将使用一个新选项编译,引入到,以便通过所谓的retpoline执行间接调用。 这似乎是一个新发明的术语,因为谷歌搜索只是最近才使用(通常都是在2018年)。 1但是,它不是Linux特有的--类似或相同的构造似乎被用作其他操作系统缓解策略的一部分。

    • 我们知道主存域很少:年轻的、终生的(旧的gen)和PermGen。 年轻领域分为伊甸园和幸存者(有两个)。 OldGen用于生存的对象。 MaxTenuringThreshold防止对象过早地被最终复制到OldGen空间。这很清楚,也很容易理解。 但是它是如何工作的呢?垃圾回收器如何处理这些在MaxTenuringThreshold之前仍然存在的对象,以何种方式?它们位于何处? 对象被复制回幸存者

    • 在我加入的新项目中,他们一直交替使用术语Hibernate和JPA。所以,我试图深入研究代码并试图理解整个事情是如何工作的(我是Spring、JPA和Hibernate世界的新手)。我将尝试将代码放在这里以更好地理解:1)有一个@Configuration类,其中有以下内容: 因此,在这个配置类中,我们返回一个EntityManagerFactory。 2) 然后是一个标记为@persistor的

    • 我正在尝试更新spring缓存中的值,但是@cacheput并没有替换实际值,而是使用相同的键放入另一个值: CacheName:NotimeCache: 键:SYSTEM_STATUS,值:on 键:SYSTEM_STATUS,值:off

    • 因此,我需要开始考虑关联,最好是利用我对并发工具的现有知识来加快进程。 我试着为他们跟踪Google codelab,虽然它给了我一点理解,但它也提出了许多未回答的问题,所以我试图通过编写一些代码、调试和查看日志输出来弄脏我的手。 根据我的理解,一个coroutine由两个主要构件组成;挂起函数是您执行工作的地方,而coroutine上下文是您执行挂起函数的地方,这样您就可以对coroutine将

    • 我有一些这样的代码: 根据文件: mergeDelayError:将发出可观测值的可观测值展平为一个可观测值,使观察者能够从所有源可观测值接收所有成功发出的项目,而不会被其中一个可观测值的错误通知打断。 到目前为止,我理解。我的问题是关于take()方法:它会等待所有可观察对象返回某个结果,然后再获取第一个结果,还是从第一个完成的可观察对象获取第一个结果? TIA,