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
- RulePatternOps.cs
- XmlElementList.cs
- MissingFieldException.cs
- TraceLevelStore.cs
- XmlSchemaSet.cs
- UpdateManifestForBrowserApplication.cs
- RelationshipSet.cs
- SecondaryViewProvider.cs
- Overlapped.cs
- ObjectDataSourceStatusEventArgs.cs
- ConsoleKeyInfo.cs
- Timer.cs
- XmlSchemaComplexContent.cs
- HealthMonitoringSection.cs
- PublisherIdentityPermission.cs
- DSASignatureDeformatter.cs
- SByteConverter.cs
- BinaryEditor.cs
- XMLUtil.cs
- Executor.cs
- SkewTransform.cs
- PseudoWebRequest.cs
- RuntimeEnvironment.cs
- TableNameAttribute.cs
- PermissionRequestEvidence.cs
- XmlIncludeAttribute.cs
- AmbientLight.cs
- LabelDesigner.cs
- ServiceBusyException.cs
- ValidationErrorCollection.cs
- CustomErrorCollection.cs
- QuaternionRotation3D.cs
- SafeBitVector32.cs
- StatusBarDrawItemEvent.cs
- ModifierKeysConverter.cs
- AppliedDeviceFiltersEditor.cs
- Model3DGroup.cs
- SoapAttributes.cs
- SequenceDesigner.cs
- WorkflowServiceHost.cs
- NullNotAllowedCollection.cs
- ThreadInterruptedException.cs
- WorkflowEventArgs.cs
- HttpApplicationFactory.cs
- ValueUtilsSmi.cs
- ServiceElementCollection.cs
- SerialPinChanges.cs
- QfeChecker.cs
- LinearQuaternionKeyFrame.cs
- ManipulationDevice.cs
- InstanceValue.cs
- DSASignatureFormatter.cs
- EntityConnectionStringBuilderItem.cs
- XPathScanner.cs
- Suspend.cs
- VariableAction.cs
- SourceChangedEventArgs.cs
- LocatorGroup.cs
- Metafile.cs
- ConstraintConverter.cs
- ImageDesigner.cs
- WarningException.cs
- ExtensionDataReader.cs
- BasicExpandProvider.cs
- EmptyEnumerator.cs
- DirectoryNotFoundException.cs
- HtmlInputPassword.cs
- CellCreator.cs
- ValueSerializerAttribute.cs
- DBSqlParserTableCollection.cs
- ServiceHandle.cs
- ExpressionHelper.cs
- DocumentPageHost.cs
- MoveSizeWinEventHandler.cs
- CodeArrayIndexerExpression.cs
- WorkflowIdleBehavior.cs
- NotSupportedException.cs
- Matrix3D.cs
- IsolatedStorageFile.cs
- DynamicScriptObject.cs
- StringConcat.cs
- SoapIncludeAttribute.cs
- ThaiBuddhistCalendar.cs
- ObjectAnimationUsingKeyFrames.cs
- IntMinMaxAggregationOperator.cs
- XNodeValidator.cs
- FaultImportOptions.cs
- OdbcFactory.cs
- SemanticBasicElement.cs
- Material.cs
- UserControlParser.cs
- HandlerFactoryWrapper.cs
- InfoCardCryptoHelper.cs
- HexParser.cs
- ElementsClipboardData.cs
- RuleConditionDialog.Designer.cs
- FreezableCollection.cs
- CodeTypeMemberCollection.cs
- Thickness.cs
- ImageIndexEditor.cs