Неожиданный конец файла. Следующие элементы не закрыты: Cookie, SecurityContextToken. Строка 1, позиция 2998

Я реализовал аутентификацию ADFS для приложения asp.net 4.0. Я разместил приложение в производственной среде с конфигурацией webfarm. Веб-сайт работает хорошо, и все изображения правильно отображаются в браузере IE8. Но когда я попытался просмотреть приложение в браузере Safari, сайт иногда не работает, и изображения также не отображаются должным образом.

С помощью Fiddler я обнаружил, что иногда изображения не отображаются должным образом и выдается следующая ошибка:

Exception information:
Exception type: XmlException
Exception message: Unexpected end of file. Following elements are not closed: Cookie, SecurityContextToken. Line 1, position 2998.

Thread information:
    Thread ID: 12
    Thread account name: CT\acmeweb
    Is impersonating: False
    Stack trace:    at System.Xml.XmlExceptionHelper.ThrowXmlException(XmlDictionaryReader reader, String res, String arg1, String arg2, String arg3)
   at System.Xml.XmlExceptionHelper.ThrowUnexpectedEndOfFile(XmlDictionaryReader reader)
   at System.Xml.XmlBaseReader.MoveToEndOfFile()
   at System.Xml.XmlUTF8TextReader.Read()
   at System.Xml.XmlDictionaryReader.ReadContentAsChars(Char[] chars, Int32 offset, Int32 count)
   at System.Xml.XmlBaseReader.ReadBytes(Encoding encoding, Int32 byteBlock, Int32 charBlock, Byte[] buffer, Int32 offset, Int32 byteCount, Boolean readContent)
   at System.Xml.XmlBaseReader.ReadContentAsBase64(Byte[] buffer, Int32 offset, Int32 count)
   at System.Xml.XmlDictionaryReader.ReadContentAsBytes(Boolean base64, Int32 maxByteArrayContentLength)
   at System.Xml.XmlDictionaryReader.ReadContentAsBase64(Int32 maxByteArrayContentLength, Int32 maxInitialCount)
   at System.Xml.XmlBaseReader.ReadContentAsBase64()
   at System.Xml.XmlDictionaryReader.ReadElementContentAsBase64()
   at Microsoft.IdentityModel.Tokens.SessionSecurityTokenHandler.ReadToken(XmlReader reader, SecurityTokenResolver tokenResolver)
   at Microsoft.IdentityModel.Tokens.SessionSecurityTokenHandler.ReadToken(Byte[] token, SecurityTokenResolver tokenResolver)
   at Microsoft.IdentityModel.Web.SessionAuthenticationModule.ReadSessionTokenFromCookie(Byte[] sessionCookie)
   at Microsoft.IdentityModel.Web.SessionAuthenticationModule.TryReadSessionTokenFromCookie(SessionSecurityToken& sessionToken)
   at Microsoft.IdentityModel.Web.SessionAuthenticationModule.OnAuthenticateRequest(Object sender, EventArgs eventArgs)
   at System.Web.HttpApplication.SyncEventExecutionStep.System.Web.HttpApplication.IExecutionStep.Execute()
   at System.Web.HttpApplication.ExecuteStep(IExecutionStep step, Boolean& completedSynchronously)

Затем я попытался перейти по указанной ниже ссылке:

http://social.msdn.microsoft.com/Forums/en/Geneva/thread/ea00ec3f-ebdf-427c-929f-d4a196650552

Но она также не сработала. Затем я попытался остановить один сервер в конфигурации webfarm и обнаружил, что сайт работает нормально в браузере IE8 и Safari. В браузере IE8 он работает постоянно, и все изображения отображаются правильно, но в браузере Safari этого не происходит в случае, когда оба сервера в веб-ферме включены.

При анализе я обнаружил, что из ADFS я получаю информацию о претензиях в виде cookie, и длина cookie больше. Для браузера IE8 длина cookie больше, а для Safari допустимый предел составляет 4097 символов.

Поэтому я решил максимально увеличить лимит cookie для браузера Safari.

Может ли кто-нибудь помочь мне решить эту проблему, предоставив какой-либо пример кода.

Спасибо и с уважением, Сантош Кумар Патро

6
задан Ken White 1 February 2012 в 22:45
поделиться