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
- SiteMapPath.cs
- DebugView.cs
- DesignBinding.cs
- LinearGradientBrush.cs
- TypeHelpers.cs
- SoapReflectionImporter.cs
- HtmlSelect.cs
- DeviceSpecificChoiceCollection.cs
- BooleanKeyFrameCollection.cs
- CalendarDay.cs
- StylusPointDescription.cs
- GenericTypeParameterConverter.cs
- IndexOutOfRangeException.cs
- HtmlInputButton.cs
- SubMenuStyleCollection.cs
- XPathNodeList.cs
- BindValidationContext.cs
- ConsumerConnectionPoint.cs
- FreeFormDesigner.cs
- SizeConverter.cs
- CompositeCollection.cs
- XmlReflectionMember.cs
- CheckBoxAutomationPeer.cs
- HostingMessageProperty.cs
- ServerTooBusyException.cs
- SignatureHelper.cs
- Label.cs
- LinqDataSourceUpdateEventArgs.cs
- Timeline.cs
- FrameworkElementAutomationPeer.cs
- Classification.cs
- ImageBrush.cs
- TaskFormBase.cs
- BrowserTree.cs
- InkCanvasAutomationPeer.cs
- Endpoint.cs
- FixedSOMTableCell.cs
- PagePropertiesChangingEventArgs.cs
- SqlNamer.cs
- XmlSerializationWriter.cs
- cookie.cs
- InputBinding.cs
- DataGridItem.cs
- TimeStampChecker.cs
- ToolStripContentPanel.cs
- ClientProxyGenerator.cs
- IsolatedStorageException.cs
- NetworkInformationPermission.cs
- GPPOINT.cs
- CodeTypeReference.cs
- ResolveRequestResponseAsyncResult.cs
- SkewTransform.cs
- ObjectListSelectEventArgs.cs
- IdnMapping.cs
- MessageQueueInstaller.cs
- CryptoStream.cs
- ParallelSeparator.xaml.cs
- SpellerStatusTable.cs
- SelectionEditingBehavior.cs
- FixedDSBuilder.cs
- WpfPayload.cs
- CodeMemberEvent.cs
- LicenseProviderAttribute.cs
- StrokeNodeData.cs
- DrawListViewSubItemEventArgs.cs
- listitem.cs
- codemethodreferenceexpression.cs
- CustomError.cs
- XmlCharacterData.cs
- CodeDirectoryCompiler.cs
- SqlCrossApplyToCrossJoin.cs
- SqlBulkCopyColumnMappingCollection.cs
- ObjectListItemCollection.cs
- SafeFileMappingHandle.cs
- X509SecurityToken.cs
- storepermission.cs
- InputScopeConverter.cs
- InfoCardArgumentException.cs
- CodeAssignStatement.cs
- EFTableProvider.cs
- StorageComplexPropertyMapping.cs
- ListControl.cs
- VirtualDirectoryMappingCollection.cs
- oledbconnectionstring.cs
- Panel.cs
- FieldAccessException.cs
- SplayTreeNode.cs
- ToolTip.cs
- ServiceContractAttribute.cs
- Button.cs
- Substitution.cs
- DataReceivedEventArgs.cs
- XmlChildEnumerator.cs
- Encoder.cs
- ChineseLunisolarCalendar.cs
- RenderDataDrawingContext.cs
- ProviderBase.cs
- DefaultHttpHandler.cs
- BitmapEffectInputData.cs
- SoapElementAttribute.cs