Авторизация Kerberos не работает в Chrome и FireFox, но работает в IE
Я следую этому руководству, чтобы интегрировать cas с Windows AD.
Он отлично работает в любом браузере несколько дней назад. Но не только он работает в IE, когда я использую браузер Firefox, отправляю на сервер только запрос "Обсудить TlRMTVNTUAABAAAAl4II4gAAAAAAAAAAAAAAAAAAAAGAbEdAAAADw==", после чего браузер возвращается на страницу входа в систему.
Эта проблема только недавно была обнаружена в производственной среде. У меня есть тестовая среда с той же конфигурацией, но до сих пор она работает нормально.
Я знаю, когда билет Kerberos не кэшируется на локальном компьютере, браузер отправит сообщение "Negotiate TlRMT...". Но я могу видеть тикет с помощью команды klist, и он работает в IE, значит, тикет в порядке.
Я предполагаю, что это, вероятно, вызвано некоторой конфигурацией клиента Windows или рекламного сервера, может кто-нибудь дать мне несколько советов, tks!
" https://1056-app.test.com/" уже добавлен в "network.negotiate-auth.trusted-uris" в Firefox. И я тоже пытался переустановить firefox, не работает.
Хром: 55
IE: 11
FireFox: 56
Clinet Browser OS: Windows 7
ОС AD Server: Windows Server 2008 R2
ОС Cas Server: Suse11Sp3
Вот дамп http на FireFox
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==
список клиентов
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!
команда keytab создать
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
1 ответ
Коренная причина была найдена. Потому что мы используем cname для dns, а cname не совпадает с адресом spn.
Я использую эту команду для открытия журнала отладки Firefox. ссылка на сайт
set NSPR_LOG_MODULES=negotiateauth:5
set NSPR_LOG_FILE=C://firefox.log
./firefox.exe
firefox.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 для типа
2. Модифицируйте браузер, чтобы отключить поиск Kerberos cname. Хромированная ссылка. Firefox не поддерживает.
Ссылка:
https://www.chromium.org/developers/design-documents/http-authentication