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
- MimePart.cs
- DoWorkEventArgs.cs
- RectValueSerializer.cs
- FreeFormPanel.cs
- SystemGatewayIPAddressInformation.cs
- DrawingGroup.cs
- VirtualDirectoryMapping.cs
- ButtonStandardAdapter.cs
- DbProviderFactory.cs
- ScriptingJsonSerializationSection.cs
- XmlWhitespace.cs
- FloaterParagraph.cs
- SiteMapProvider.cs
- HuffModule.cs
- EventSchemaTraceListener.cs
- _SafeNetHandles.cs
- ReachObjectContext.cs
- MarkupExtensionParser.cs
- ProgressBar.cs
- DirectionalLight.cs
- ControlDesignerState.cs
- streamingZipPartStream.cs
- ServiceNameElement.cs
- HtmlGenericControl.cs
- CookielessData.cs
- SchemaElementDecl.cs
- CalendarDayButton.cs
- ReferenceConverter.cs
- DBConnection.cs
- DataSourceHelper.cs
- ElementHostAutomationPeer.cs
- XmlBinaryReaderSession.cs
- VideoDrawing.cs
- HandledEventArgs.cs
- StrokeNode.cs
- XamlTypeMapper.cs
- ResourceContainer.cs
- ProfessionalColorTable.cs
- DiscoveryVersionConverter.cs
- Visual3DCollection.cs
- MessageQueue.cs
- FtpWebResponse.cs
- CodeRegionDirective.cs
- SecurityDescriptor.cs
- CustomAttribute.cs
- ExpressionTextBox.xaml.cs
- LicenseContext.cs
- Size3DConverter.cs
- QilFactory.cs
- StreamAsIStream.cs
- Signature.cs
- ViewGenerator.cs
- EventHandlersStore.cs
- HostProtectionPermission.cs
- _SingleItemRequestCache.cs
- IDQuery.cs
- SqlInfoMessageEvent.cs
- DataBindingCollectionConverter.cs
- TextView.cs
- DefinitionBase.cs
- WmlObjectListAdapter.cs
- ActivityXRefPropertyEditor.cs
- OperationSelectorBehavior.cs
- InitializeCorrelation.cs
- NativeObjectSecurity.cs
- FastEncoderWindow.cs
- ImportException.cs
- DateTimeFormatInfoScanner.cs
- DataStreamFromComStream.cs
- BaseValidator.cs
- ToolStripPanelRow.cs
- Classification.cs
- WebPartCatalogAddVerb.cs
- RemotingConfiguration.cs
- Ipv6Element.cs
- SelectorAutomationPeer.cs
- AsymmetricKeyExchangeDeformatter.cs
- IxmlLineInfo.cs
- SpeakInfo.cs
- SqlAliaser.cs
- clipboard.cs
- TogglePatternIdentifiers.cs
- BypassElement.cs
- ReadWriteControlDesigner.cs
- RequestBringIntoViewEventArgs.cs
- SecurityTokenAuthenticator.cs
- HitTestParameters.cs
- FormViewDesigner.cs
- ModelTreeEnumerator.cs
- VirtualPathData.cs
- ArrangedElement.cs
- XmlAttributeCollection.cs
- HttpWriter.cs
- TransactedBatchContext.cs
- WebPartEditorOkVerb.cs
- EventRoute.cs
- SqlCommandBuilder.cs
- CardSpacePolicyElement.cs
- DiscoveryReferences.cs
- cache.cs