Code:
/ Dotnetfx_Vista_SP2 / Dotnetfx_Vista_SP2 / 8.0.50727.4016 / DEVDIV / depot / DevDiv / releases / whidbey / NetFxQFE / ndp / fx / src / Net / System / Net / _CookieModule.cs / 1 / _CookieModule.cs
//------------------------------------------------------------------------------ //// Copyright (c) Microsoft Corporation. All rights reserved. // //----------------------------------------------------------------------------- namespace System.Net { internal static class CookieModule { // fields // constructors // properties // methods internal static void OnSendingHeaders(HttpWebRequest httpWebRequest) { GlobalLog.Print("CookieModule::OnSendingHeaders()"); try { if (httpWebRequest.CookieContainer == null) { return; } // // remove all current cookies. This could be a redirect // httpWebRequest.Headers.RemoveInternal(HttpKnownHeaderNames.Cookie); // // add in the new headers from the cookie container for this request // string optCookie2; string cookieString = httpWebRequest.CookieContainer.GetCookieHeader( httpWebRequest.Address, out optCookie2); if (cookieString.Length > 0) { GlobalLog.Print("CookieModule::OnSendingHeaders() setting Cookie header to:[" + cookieString + "]"); httpWebRequest.Headers[HttpKnownHeaderNames.Cookie] = cookieString; //< } } catch { } } internal static void OnReceivedHeaders(HttpWebRequest httpWebRequest) { GlobalLog.Print("CookieModule.OnReceivedHeaders()"); // // if the app doesn't want us to handle cookies then there's nothing // to do. Note that we're leaving open the possibility that these // settings could be changed between the request being made and the // response received // try { if (httpWebRequest.CookieContainer == null) { return; } // // add any received cookies for this response to the container // HttpWebResponse response = httpWebRequest._HttpResponse as HttpWebResponse; if (response == null) { return; } CookieCollection cookies = null; try { string cookieString = response.Headers.SetCookie; GlobalLog.Print("CookieModule::OnSendingHeaders() received Set-Cookie:[" + cookieString + "]"); if ((cookieString != null) && (cookieString.Length > 0)) { cookies = httpWebRequest.CookieContainer.CookieCutter( response.ResponseUri, HttpKnownHeaderNames.SetCookie, cookieString, false); } } catch { } try { string cookieString = response.Headers.SetCookie2; GlobalLog.Print("CookieModule::OnSendingHeaders() received Set-Cookie2:[" + cookieString + "]"); if ((cookieString != null) && (cookieString.Length > 0)) { CookieCollection cookies2 = httpWebRequest.CookieContainer.CookieCutter( response.ResponseUri, HttpKnownHeaderNames.SetCookie2, cookieString, false); if (cookies != null && cookies.Count != 0) { cookies.Add(cookies2); } else { cookies = cookies2; } } } catch { } if (cookies != null) { response.Cookies = cookies; } } catch { } } } } // File provided for Reference Use Only by Microsoft Corporation (c) 2007. //------------------------------------------------------------------------------ //// Copyright (c) Microsoft Corporation. All rights reserved. // //----------------------------------------------------------------------------- namespace System.Net { internal static class CookieModule { // fields // constructors // properties // methods internal static void OnSendingHeaders(HttpWebRequest httpWebRequest) { GlobalLog.Print("CookieModule::OnSendingHeaders()"); try { if (httpWebRequest.CookieContainer == null) { return; } // // remove all current cookies. This could be a redirect // httpWebRequest.Headers.RemoveInternal(HttpKnownHeaderNames.Cookie); // // add in the new headers from the cookie container for this request // string optCookie2; string cookieString = httpWebRequest.CookieContainer.GetCookieHeader( httpWebRequest.Address, out optCookie2); if (cookieString.Length > 0) { GlobalLog.Print("CookieModule::OnSendingHeaders() setting Cookie header to:[" + cookieString + "]"); httpWebRequest.Headers[HttpKnownHeaderNames.Cookie] = cookieString; //< } } catch { } } internal static void OnReceivedHeaders(HttpWebRequest httpWebRequest) { GlobalLog.Print("CookieModule.OnReceivedHeaders()"); // // if the app doesn't want us to handle cookies then there's nothing // to do. Note that we're leaving open the possibility that these // settings could be changed between the request being made and the // response received // try { if (httpWebRequest.CookieContainer == null) { return; } // // add any received cookies for this response to the container // HttpWebResponse response = httpWebRequest._HttpResponse as HttpWebResponse; if (response == null) { return; } CookieCollection cookies = null; try { string cookieString = response.Headers.SetCookie; GlobalLog.Print("CookieModule::OnSendingHeaders() received Set-Cookie:[" + cookieString + "]"); if ((cookieString != null) && (cookieString.Length > 0)) { cookies = httpWebRequest.CookieContainer.CookieCutter( response.ResponseUri, HttpKnownHeaderNames.SetCookie, cookieString, false); } } catch { } try { string cookieString = response.Headers.SetCookie2; GlobalLog.Print("CookieModule::OnSendingHeaders() received Set-Cookie2:[" + cookieString + "]"); if ((cookieString != null) && (cookieString.Length > 0)) { CookieCollection cookies2 = httpWebRequest.CookieContainer.CookieCutter( response.ResponseUri, HttpKnownHeaderNames.SetCookie2, cookieString, false); if (cookies != null && cookies.Count != 0) { cookies.Add(cookies2); } else { cookies = cookies2; } } } catch { } if (cookies != null) { response.Cookies = cookies; } } catch { } } } } // File provided for Reference Use Only by Microsoft Corporation (c) 2007.
Link Menu
This book is available now!
Buy at Amazon US or
Buy at Amazon UK
- StrongNameMembershipCondition.cs
- Automation.cs
- CreateUserWizardStep.cs
- BaseCodePageEncoding.cs
- RoleGroup.cs
- IntegerValidator.cs
- _WinHttpWebProxyDataBuilder.cs
- UnsafeNativeMethods.cs
- FixedPosition.cs
- CodeSnippetStatement.cs
- PersistenceMetadataNamespace.cs
- InvariantComparer.cs
- XMLSyntaxException.cs
- DBCSCodePageEncoding.cs
- AppearanceEditorPart.cs
- SqlCacheDependencyDatabase.cs
- Debug.cs
- DataColumnPropertyDescriptor.cs
- PlatformCulture.cs
- BitConverter.cs
- ContainerControl.cs
- ToolStripPanelCell.cs
- Run.cs
- HttpFormatExtensions.cs
- InvokeHandlers.cs
- ToolStripDropDown.cs
- AddressHeaderCollectionElement.cs
- ThicknessAnimation.cs
- ExtenderProvidedPropertyAttribute.cs
- ACE.cs
- CngUIPolicy.cs
- DataGridHelper.cs
- ReaderWriterLockWrapper.cs
- SqlUtils.cs
- BindableTemplateBuilder.cs
- DbDataRecord.cs
- Menu.cs
- GetMemberBinder.cs
- BlobPersonalizationState.cs
- InstanceDataCollection.cs
- COM2AboutBoxPropertyDescriptor.cs
- AnnouncementInnerClientCD1.cs
- PreviewPrintController.cs
- UnaryExpressionHelper.cs
- SafeHandle.cs
- WindowsScroll.cs
- ProxyAttribute.cs
- MetadataException.cs
- MultipartContentParser.cs
- ByteStreamMessageEncoder.cs
- WebPartRestoreVerb.cs
- PickBranch.cs
- ProfileInfo.cs
- mansign.cs
- AnnotationAuthorChangedEventArgs.cs
- EntityViewContainer.cs
- CompiledQuery.cs
- FieldNameLookup.cs
- _NegotiateClient.cs
- RefreshPropertiesAttribute.cs
- ComEventsInfo.cs
- CustomValidator.cs
- COM2TypeInfoProcessor.cs
- XmlMembersMapping.cs
- ControlCachePolicy.cs
- FloaterParagraph.cs
- ImagingCache.cs
- XPathScanner.cs
- MapPathBasedVirtualPathProvider.cs
- AnchorEditor.cs
- WebPartDescriptionCollection.cs
- CapabilitiesRule.cs
- DiscoveryClient.cs
- TextWriterTraceListener.cs
- ClientConfigPaths.cs
- OleDbConnection.cs
- SpnegoTokenAuthenticator.cs
- RoutedUICommand.cs
- UnsafeNativeMethodsMilCoreApi.cs
- PersonalizationDictionary.cs
- DataTransferEventArgs.cs
- EntityType.cs
- TranslateTransform.cs
- FixedTextView.cs
- PermissionSet.cs
- UrlMappingsModule.cs
- NameGenerator.cs
- ResourceType.cs
- XmlText.cs
- KeyConverter.cs
- EditableLabelControl.cs
- Console.cs
- GlobalDataBindingHandler.cs
- InputBinding.cs
- Processor.cs
- RangeValuePatternIdentifiers.cs
- RelationshipEnd.cs
- SystemIcmpV6Statistics.cs
- AttachedPropertyMethodSelector.cs
- SqlDependencyUtils.cs