google-chrome - Kerberos 授权不适用于 Chrome 和 FireFox,但适用于 IE

标签 google-chrome firefox kerberos spnego negotiate

我关注这个 guide将 cas 与 Windows AD 集成。

几天前它在每个浏览器上都能正常工作。但它不仅适用于 IE,当我使用 firefox 浏览器时,只向服务器发送“Negotiate TlRMTVNTUAABAAAAl4II4gAAAAAAAAAAAAAAAAAAAAAGAbEdAAAADw==”,然后浏览器返回到 cas 登录页面。

这个问题最近才在生产环境中发现。我有一个配置相同的测试环境,但到目前为止它工作正常。

我知道当 kerberos 票证未缓存在本地时,浏览器将发送“协商 TlRMT...”。但是我可以使用 klist 命令查看票证,并且它适用于 IE 意味着
票还行。

我想这可能是由 Windows 客户端或广告服务器的某些配置引起的,谁能给我一些建议,tks!

"https://1056-app.test.com" have already add to "network.negotiate-auth.trusted-uris" on firefox. And I also tried to reinstall firefox, not works.

Chrome: 55

IE:11

FireFox:56

Clinet Browser OS:Windows 7

AD Server OS: Windows Server 2008 R2

Cas Server OS: Suse11Sp3



这是 FireFox 上的 http 转储
GET https://1056-app.test.com/cas/login 401 Unauthorized

Response Headers
Server : nginx/1.8.0
Date : Fri, 13 Oct 2017 10:38:08 GMT
Content-Type : text/html;charset=UTF-8
Transfer-Encoding : chunked
Connection : keep-alive
Pragma : no-cache
Expires : Thu, 01 Jan 1970 00:00:00 GMT
Cache-Control : no-cache
WWW-Authenticate : Negotiate
Content-Language : en-US
Content-Encoding : gzip
Vary : Accept-Encoding

Request Headers
Host : 1056-app.test.com
User-Agent : Mozilla/5.0 (Windows NT 6.1; WOW64; rv:53.0) Gecko/20100101 Firefox/53.0
Accept : text/html,application/xhtml+xml,application/xml;q=0.9,*/*;q=0.8
Accept-Language : en-US,en;q=0.5
Accept-Encoding : gzip, deflate, br
Cookie : JSESSIONID=EE40B3C3FAFB30D13F45DC612E4D383ECC95916DBE12BEDDE21E9D933893964A4EB867271389530BC8A4B6E9B485E944B952
Connection : keep-alive
Upgrade-Insecure-Requests : 1




GET https://1056-app.test.com/cas/login 401 Unauthorized

Response Headers
Server : nginx/1.8.0
Date : Fri, 13 Oct 2017 10:38:08 GMT
Content-Type : text/html;charset=UTF-8
Transfer-Encoding : chunked
Connection : keep-alive
Pragma : no-cache
Expires : Thu, 01 Jan 1970 00:00:00 GMT
Cache-Control : no-cache
Content-Language : en-US
Content-Encoding : gzip
Vary : Accept-Encoding

Request Headers
Host : 1056-app.test.com
User-Agent : Mozilla/5.0 (Windows NT 6.1; WOW64; rv:53.0) Gecko/20100101 Firefox/53.0
Accept : text/html,application/xhtml+xml,application/xml;q=0.9,*/*;q=0.8
Accept-Language : en-US,en;q=0.5
Accept-Encoding : gzip, deflate, br
Cookie : JSESSIONID=EE40B3C3FAFB30D13F45DC612E4D383ECC95916DBE12BEDDE21E9D933893964A4EB867271389530BC8A4B6E9B485E944B952
Connection : keep-alive
Upgrade-Insecure-Requests : 1
Authorization : Negotiate TlRMTVNTUAABAAAAl4II4gAAAAAAAAAAAAAAAAAAAAAGAbEdAAAADw==

客户端上的 klist
Client: huangq @ SWI.TEST.NET
Server: HTTP/1056-app.test.com @ SWI.TEST.NET
KerbTicket Encryption Type: RSADSI RC4-HMAC(NT)
Ticket Flags 0x40a00000 -> forwardable renewable pre_authent
Start Time: 10/13/2017 12:52:34 (local)
End Time:   10/13/2017 22:11:01 (local)
Renew Time: 10/20/2017 12:11:01 (local)
Session Key Type: RSADSI RC4-HMAC(NT)

客户端上的 setspn -Q cmd
C:\Users\huangq>setspn -Q HTTP/1056-app.test.com
Checking domain DC=swi,DC=test,DC=net
CN=SOWSLdapA,OU=Service,OU=_Users,DC=swi,DC=test,DC=net
    HTTP/1056-app.test.com
Existing SPN found! 

key 表创建命令
ktpass.exe /out D:\\1056-app.keytab /princ HTTP/1056-app.test.com@SWI.TEST.NET /pass xxx /mapuser SOWSLdapA@swi.test.net /ptype KRB5_NT_PRINCIPAL /crypto RC4-HMAC-NT

最佳答案

根本原因已经找到。因为我们使用 cname 作为 dns,而 cname 与 spn 地址不匹配。

我用这个命令打开firefox协商调试日志。 link

set NSPR_LOG_MODULES=negotiateauth:5
set NSPR_LOG_FILE=C://firefox.log
./firefox.exe

火狐.log
[Lazy Idle]: D/negotiateauth   Sending a token of length 9800
[Main Thread]: D/negotiateauth   service = 1056-app.test.com
[Main Thread]: D/negotiateauth   using negotiate-sspi
[Main Thread]: D/negotiateauth   nsAuthSSPI::Init
[Main Thread]: D/negotiateauth Using SPN of [HTTP/***-nginx-elb-***.eu-west-1.elb.amazonaws.com]

解决方案:

1.将DNS改为A类型

2.修改浏览器禁用kerberos cname查找。 Chrome link .火狐不支持。

引用:

https://www.chromium.org/developers/design-documents/http-authentication

关于google-chrome - Kerberos 授权不适用于 Chrome 和 FireFox,但适用于 IE,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/46740179/

相关文章:

javascript - 如何使用书签通过电子邮件发送当前页面的链接而不覆盖选项卡的内容?

css - Flexbox 渲染被最新的 Chrome 破坏了

css - 我的菜单中使用的填充在 Firefox 和 Chrome 之间相差 1px,我该如何解决这个问题?

java - 如何生成 login.conf 和 krb5.ini 以与 Java Kerbernos Http 客户端一起使用以通过 Active Directory kerberos 进行身份验证?

css - Google Web 字体无法在 Windows 7 上的 Chrome 中正确显示

google-chrome - 如何更改 Chrome 开发者工具的图标?

当返回 false 时,Javascript AJAX 调用在 Firefox 中失败;

html - FF & Chrome : Text bounding box difference in Windows/Linux

hadoop - 在 Kerberized 和非 Kerberized 环境之间启用通信的方法

sql-server - SQL Server 网络接口(interface)库无法取消注册服务主体名称 (SPN)