Code:
/ 4.0 / 4.0 / DEVDIV_TFS / Dev10 / Releases / RTMRel / ndp / fx / src / Net / System / Net / _CookieModule.cs / 1305376 / _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.GetRemoteResourceUri(), 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.GetRemoteResourceUri(), 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
- Base64Stream.cs
- CharEntityEncoderFallback.cs
- PrivilegedConfigurationManager.cs
- JoinGraph.cs
- WebPartZoneCollection.cs
- SmiEventSink.cs
- XmlDataLoader.cs
- XsltQilFactory.cs
- RepeaterItem.cs
- BamlVersionHeader.cs
- RecommendedAsConfigurableAttribute.cs
- StylusButtonEventArgs.cs
- TabletDevice.cs
- StorageAssociationTypeMapping.cs
- HtmlInputHidden.cs
- CriticalExceptions.cs
- PieceDirectory.cs
- SplitterPanel.cs
- CellParaClient.cs
- PropertyMapper.cs
- CheckedPointers.cs
- IProvider.cs
- SafeFileMapViewHandle.cs
- BitmapEffectOutputConnector.cs
- SQLUtility.cs
- OleAutBinder.cs
- ContextMenu.cs
- PropertyKey.cs
- PlatformNotSupportedException.cs
- HtmlControlAdapter.cs
- SchemaImporterExtensionsSection.cs
- DSACryptoServiceProvider.cs
- Options.cs
- Utils.cs
- RawStylusInput.cs
- DataGridViewIntLinkedList.cs
- CharAnimationUsingKeyFrames.cs
- XmlDataDocument.cs
- ResolveNameEventArgs.cs
- OdbcConnectionHandle.cs
- CodeGeneratorOptions.cs
- DbMetaDataFactory.cs
- RuleSettingsCollection.cs
- ObjectDataProvider.cs
- InlineObject.cs
- DataRecordInternal.cs
- Size.cs
- NegatedConstant.cs
- CipherData.cs
- EventLogTraceListener.cs
- HtmlInputFile.cs
- TemplateApplicationHelper.cs
- BamlLocalizationDictionary.cs
- SimpleLine.cs
- MultiSelectRootGridEntry.cs
- SimpleBitVector32.cs
- NavigatingCancelEventArgs.cs
- DataServiceRequest.cs
- SrgsDocumentParser.cs
- IODescriptionAttribute.cs
- CustomErrorsSection.cs
- CodeArgumentReferenceExpression.cs
- StateDesigner.TransitionInfo.cs
- GuidelineCollection.cs
- SHA1.cs
- DataGridColumnReorderingEventArgs.cs
- PersonalizableAttribute.cs
- AnimationClockResource.cs
- RTLAwareMessageBox.cs
- TrustLevelCollection.cs
- OutputCacheModule.cs
- DelegateSerializationHolder.cs
- XPathMessageFilterTable.cs
- DesignTimeParseData.cs
- RemotingAttributes.cs
- EntryPointNotFoundException.cs
- MessageAction.cs
- Message.cs
- SplitterPanelDesigner.cs
- String.cs
- Collection.cs
- FieldMetadata.cs
- AnnouncementSendsAsyncResult.cs
- DataGridViewLayoutData.cs
- RegexCompiler.cs
- TimeSpanSecondsOrInfiniteConverter.cs
- ACE.cs
- FlowDocumentScrollViewer.cs
- COM2IPerPropertyBrowsingHandler.cs
- SettingsBindableAttribute.cs
- CodeGenerator.cs
- ConfigurationSectionHelper.cs
- TablePatternIdentifiers.cs
- SupportsEventValidationAttribute.cs
- GroupBoxRenderer.cs
- CategoriesDocument.cs
- RouteItem.cs
- FileDetails.cs
- CodeTypeDelegate.cs
- SafeNativeMethods.cs