java - 为什么基本 AUTH 框在 Chrome 中弹出两次,但在使用 spnego SSO 的 Firefox 中却不会弹出

标签 java single-sign-on spnego

我有一个非常普通的 spnego SSO 设置,它针对 Active Directory 服务器进行身份验证。 IE SSO 包含 NEGOTIATE header cookie,该 cookie 可以在不提示用户的情况下正确进行身份验证。 Firefox 和 Chrome 不包含 SSO cookie,因此无法恢复到基本身份验证。他们确实正确接收了用户名和密码并正确登录。

但是,我的小烦恼是,它在 Firefox 中提示一次,但在 Chrome 中提示输入密码两次。

关于为什么会提示两次有什么想法吗?

为了完整性,请进行以下设置:

<filter>

    <filter-name>SpnegoHttpFilter</filter-name>

    <filter-class>net.sourceforge.spnego.SpnegoHttpFilter</filter-class>

    <init-param>
        <param-name>spnego.allow.basic</param-name>
        <param-value>true</param-value>
    </init-param>

    <init-param>
        <param-name>spnego.allow.localhost</param-name>
        <param-value>true</param-value>
    </init-param>

    <init-param>
        <param-name>spnego.allow.unsecure.basic</param-name>
        <param-value>true</param-value>
    </init-param>

    <init-param>
        <param-name>spnego.login.client.module</param-name>
        <param-value>spnego-client</param-value>
    </init-param>

    <init-param>
        <param-name>spnego.krb5.conf</param-name>
        <param-value>xxxxxxxxxxxxx/krb5.conf</param-value>
    </init-param>

    <init-param>
        <param-name>spnego.login.conf</param-name>
        <param-value>xxxxxxxxxxxx/login.conf</param-value>
    </init-param>

    <init-param>
        <param-name>spnego.preauth.username</param-name>
        <param-value>xxxxxxxxxxxxxxxx</param-value>
    </init-param>

    <init-param>
        <param-name>spnego.preauth.password</param-name>
        <param-value>xxxxxxxxxxxxxxxx</param-value>
    </init-param>

    <init-param>
        <param-name>spnego.login.server.module</param-name>
        <param-value>spnego-server</param-value>
    </init-param>



    <init-param>
        <param-name>spnego.prompt.ntlm</param-name>
        <param-value>true</param-value>
    </init-param>

    <init-param>
        <param-name>spnego.allow.delegation</param-name>
        <param-value>true</param-value>
    </init-param>


</filter>

最佳答案

这并不是解释为什么它会弹出两次,而是在 chrome 中调试它的一种方法。

浏览到 chrome:net-internals#events,您可以看到 401 身份验证协商。 401 请求和响应不会出现在 Chrome 开发工具的网络选项卡中,因此这是您可以获得的唯一线索。

编辑更新 - Chrome 似乎并不总是发送 Authorization header 进行digest。要么是因为管道、身份验证缓存错误,要么是由于 url“继承”授权的启发。

来自https://groups.google.com/d/msg/chromium-discuss/9ASzOBdBrTQ/wUWFlwFYwaMJ

Since chromium will not pre-emptively send the authorization for inferred protection space, it will keep entering that loop.

[...]

Support for Digest is likely, but a little sketchier, since the digest auth model is broken under pipelining (next nonce is controlled by previous server responses (Authorization-Info).

因为 htdigest 在每次页面加载时都会导致两个登录对话框,所以我切换到基本身份验证,因为我的网站已经使用 HTTPS 来确保安全。 Basic 和 Digest 没有定义需要发送授权 token 的 URL 以及缓存密码或 token 的时间的方案。因此它比 cookie 更慢且安全性更低。我以后会尽量避免这种方案。

关于java - 为什么基本 AUTH 框在 Chrome 中弹出两次,但在使用 spnego SSO 的 Firefox 中却不会弹出,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/20843918/

相关文章:

java - Maven 快速入门原型(prototype)不存在

java - 调用 MultipleAccountPublicClientApplication() 时,MSAL 引发 MsalClientException

Java Weld CDI 替代工厂

Java 如何使用 pdf javascript 关闭 PDF?

asp.net - 在两个站点之间共享身份验证 cookie/成员(member)提供商 - 第二个站点从不进行身份验证

android - 授权用户通过谷歌服务使用 REST API

active-directory - 使用 Kerberos 进行身份验证时登录错误

java - SPNEGO:成功协商和身份验证后的后续调用

java - 我应该如何将 SPNEGO 身份验证添加到没有第 3 方库的 servlet

java - JobBuilderFactory.get(job).incrementer(RunIdIncrementer)的作用是什么?