Code:
/ Net / Net / 3.5.50727.3053 / DEVDIV / depot / DevDiv / releases / whidbey / netfxsp / 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
- XmlSchemaExternal.cs
- DataGridViewRowErrorTextNeededEventArgs.cs
- PeerSecurityManager.cs
- CheckBoxRenderer.cs
- RoleBoolean.cs
- DefaultMemberAttribute.cs
- SettingsPropertyCollection.cs
- ResourceExpressionBuilder.cs
- DataColumn.cs
- EndPoint.cs
- SqlDataAdapter.cs
- _ListenerResponseStream.cs
- AttributeProviderAttribute.cs
- PreProcessor.cs
- DecimalAnimationUsingKeyFrames.cs
- IPPacketInformation.cs
- SeekStoryboard.cs
- ObservableCollection.cs
- DiscardableAttribute.cs
- Transform3DGroup.cs
- AppModelKnownContentFactory.cs
- LinkArea.cs
- Msec.cs
- MobileControlsSection.cs
- Stack.cs
- Enum.cs
- SmiSettersStream.cs
- XamlToRtfParser.cs
- HwndSource.cs
- SiteOfOriginPart.cs
- QueryOpeningEnumerator.cs
- Cursors.cs
- ListenerAdaptersInstallComponent.cs
- DependencyObjectValidator.cs
- InputBuffer.cs
- WebBrowserNavigatingEventHandler.cs
- FileSecurity.cs
- Root.cs
- TextOutput.cs
- TypeResolvingOptionsAttribute.cs
- Pair.cs
- TextAction.cs
- SystemTcpConnection.cs
- MetadataUtil.cs
- KeyEventArgs.cs
- DataGridBoundColumn.cs
- SettingsPropertyNotFoundException.cs
- EventArgs.cs
- EntityReference.cs
- EntityObject.cs
- VisualProxy.cs
- DataDocumentXPathNavigator.cs
- BackgroundWorker.cs
- SRGSCompiler.cs
- DateRangeEvent.cs
- EdmConstants.cs
- VectorConverter.cs
- DrawingCollection.cs
- unsafeIndexingFilterStream.cs
- DataGridViewColumnEventArgs.cs
- SoapAttributeOverrides.cs
- WebBrowserSiteBase.cs
- NullableIntMinMaxAggregationOperator.cs
- ArrayWithOffset.cs
- SafeEventHandle.cs
- AuthorizationSection.cs
- BinaryMethodMessage.cs
- DecimalAnimation.cs
- SafeFileHandle.cs
- Label.cs
- InvariantComparer.cs
- DetailsViewRowCollection.cs
- WorkflowViewService.cs
- DrawingContextDrawingContextWalker.cs
- ThicknessKeyFrameCollection.cs
- WindowPattern.cs
- WebServiceBindingAttribute.cs
- _SslSessionsCache.cs
- SecurityDescriptor.cs
- SafeNativeMethodsCLR.cs
- DataGridViewDataConnection.cs
- XPathQilFactory.cs
- SafeViewOfFileHandle.cs
- CodeTypeParameterCollection.cs
- _WinHttpWebProxyDataBuilder.cs
- DBCSCodePageEncoding.cs
- SessionKeyExpiredException.cs
- CharStorage.cs
- HtmlForm.cs
- BypassElementCollection.cs
- ConfigurationPropertyCollection.cs
- CategoryState.cs
- HtmlInputCheckBox.cs
- MatrixTransform3D.cs
- SpecularMaterial.cs
- DbDataAdapter.cs
- MouseButtonEventArgs.cs
- TextClipboardData.cs
- CheckPair.cs
- ElementNotAvailableException.cs