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

IDP在现有应用程序中启动SSO实施

茅昀
2023-03-14

我有一个现有的应用程序,突然间我被赋予了一项任务来实现IDP启动的SSO。有一个指向IDP的URL,点击它会要求我使用IDP提供的凭据登录,成功登录后,路径将移动到我们的应用程序,然后我的任务开始识别用户并提供正确的访问权限。我有我们的IDP提供的证书。我怎样才能做到这一点?我的应用程序是Spring MVC Java应用程序。我使用JBOSS AS 7。我以前从未做过类似的事情。有人能一步步清楚地描述一下吗?我看到了Spring SAML扩展,我无法正确理解它,无法将其与我现有的应用程序集成。我们将非常感谢您在这方面提供的任何帮助。

共有1个答案

许明朗
2023-03-14

IdP启动的SSO

IdP启动的具有POST绑定的SSO

  1. 如果用户在IdP上没有有效的本地安全上下文,在某个时刻,用户将被质询向IdP站点IdP提供其凭据。实例组织
  2. 用户提供有效凭据,并在IdP为用户创建本地登录安全上下文
  3. 用户在IdP上选择菜单选项或链接,以请求访问SP网站SP.example。通用域名格式。这会导致调用IdP的单一登录服务
  4. 单点登录服务构建一个代表用户登录安全上下文的SAML断言。由于将使用POST绑定,因此在将断言放入SAML消息之前,会对其进行数字签名。然后将消息作为名为SAMLResponse的隐藏表单控件放置在HTML表单中。(如果IdP和SP支持标识SP上特定应用程序资源的约定,则SP上的资源URL也会使用名为RelayState的隐藏表单控件编码到表单中。)单一登录服务在HTTP响应中将HTML表单发送回浏览器。为了便于使用,HTML表单通常会包含脚本代码,这些脚本代码会自动将表单发布到目标站点
  5. 由于用户操作或执行“自动提交”脚本,浏览器会发出HTTP POST请求,将表单发送到SP的断言消费者服务。服务提供者的断言使用者服务从HTML表单获取消息进行处理。必须首先验证SAML断言上的数字签名,然后处理断言内容,以便为SP上的用户创建本地登录安全上下文。完成后,SP检索RelayState数据(如果有)以确定所需的应用程序资源URL,并向浏览器发送HTTP重定向响应,指示其访问请求的资源(未显示)
  6. 进行访问检查以确定用户是否具有访问资源的正确授权。如果访问检查通过,则资源将返回到浏览器

参见saml-tech-overview-2.0

因此,如果要实现SP,必须遵循步骤5和6,否则执行步骤1-4。

对于实现,如果不能使用Spring SAML扩展,可以使用OpenSaml。

 类似资料:
  • 我在使用SimplesamlPHP实现IdP发起的登录时遇到了麻烦。了解我必须从留档中做什么并不是最容易的事情。 我将用户重定向到IdP服务器,登录后,服务器向SP发送一个XML文件,其中包含电子邮件用户的地址、ID和其他数据。这看起来像是一次成功的登录,但是此时我不知道如何处理这个XML。我应该自己解析它还是使用simplesaml?我如何验证签名? 以下是我收到的XML:

  • 这个问题是在基于SAML的IDP发起的SSO领域。作为一个POC,我有两个keycloak实例,比如keycloak1和KeyCloak2。我想做到以下几点: > 身份验证将在keycloak1上完成 keycloak1然后指向keycloak2以访问keycloak2客户端应用程序。 b)单击上面创建的saml客户端-->安装-->导出saml元数据IDPSSODescriptor并保存为sam

  • 我有一个spring security saml项目的分叉。你可以在这里看到我应用的更改:https://github . com/troy hart/spring-security-SAML/commits/nwri-sample _ simple。 SP在SSO Circle注册。如果您有SSO Circle登录名,您可以启动应用程序并测试SP启动的SSO是否有效。但是,我无法让IDP启动的S

  • 我使用SPRING SAML实现并充当SP(例如:ALPHA)。我能够执行SP启动的SSO,并能够使用IDP对用户进行身份验证。此实现中没有问题。 但在我的应用程序中,我需要访问另一个与同一IDP链接的SP(例如:BETA)url。ALPHA和BETA服务提供商都受到同一IDP的信任。在这种情况下,在通过SP INIT SSO使用IDP对用户进行ALPHA身份验证后,当BETA SP URL发生重

  • 我正在尝试使用OpenAM在现有的web应用程序中实现SSO,请参考以下链接 http://fczaja.blogspot.com/2012/06/idp-initiated-sso-and-identity_21.html ps.我的网络应用程序已经有了自己的登录页面 现在实现后得到的是,openAM登录页面在我的web应用程序中受到保护,我需要再次登录到我的应用程序 我需要的是,想跳过我的应用

  • 如何从SAML响应中判断是SP启动的SSO还是IDP启动的SSO?是否有一个属性告诉我是谁发起了SSO? 例如,在这个StackOverflow问题中:SP发起的SSO和IDP发起的SSO之间的差异,他们讨论了差异,但没有谈论XML级别本身...... SAML响应如下所示: