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
- HttpListenerContext.cs
- XmlArrayAttribute.cs
- ParallelQuery.cs
- DrawingImage.cs
- WebPartEventArgs.cs
- Rect.cs
- DataChangedEventManager.cs
- DropShadowBitmapEffect.cs
- BinaryObjectWriter.cs
- _CacheStreams.cs
- Splitter.cs
- AxDesigner.cs
- TextEditorLists.cs
- TableItemProviderWrapper.cs
- PaintEvent.cs
- WorkflowMarkupElementEventArgs.cs
- Cursors.cs
- XdrBuilder.cs
- DataGridViewAdvancedBorderStyle.cs
- ObjectDataSourceView.cs
- Attribute.cs
- GPPOINTF.cs
- HttpConfigurationSystem.cs
- SymbolType.cs
- ViewGenerator.cs
- EndpointDiscoveryMetadataCD1.cs
- Model3DGroup.cs
- Models.cs
- ValueConversionAttribute.cs
- MyContact.cs
- ToolTipAutomationPeer.cs
- X509Chain.cs
- ProfilePropertyMetadata.cs
- ReflectionUtil.cs
- TextFormatterHost.cs
- SoapAttributeAttribute.cs
- SchemaNotation.cs
- ApplyTemplatesAction.cs
- AsyncPostBackTrigger.cs
- RegexGroup.cs
- HttpResponse.cs
- TableCellCollection.cs
- XmlJsonWriter.cs
- ComEventsInfo.cs
- WebEvents.cs
- DesignerDataStoredProcedure.cs
- BeginStoryboard.cs
- ValidatedControlConverter.cs
- SoapTypeAttribute.cs
- webproxy.cs
- SqlTypeConverter.cs
- BitmapEffectDrawingContextState.cs
- InstancePersistence.cs
- Rules.cs
- PropertyGroupDescription.cs
- ResXFileRef.cs
- HtmlImageAdapter.cs
- ApplicationServicesHostFactory.cs
- DataSourceSelectArguments.cs
- SQLInt64.cs
- PictureBox.cs
- ObjectPropertyMapping.cs
- WindowsNonControl.cs
- DataReceivedEventArgs.cs
- IsolatedStorage.cs
- TextSerializer.cs
- ComponentSerializationService.cs
- BackgroundFormatInfo.cs
- AttributeQuery.cs
- OleServicesContext.cs
- _Semaphore.cs
- CheckedPointers.cs
- ServiceXNameTypeConverter.cs
- printdlgexmarshaler.cs
- GridEntryCollection.cs
- WinEventHandler.cs
- Cursors.cs
- WorkflowDispatchContext.cs
- DictionaryKeyPropertyAttribute.cs
- DataRecordObjectView.cs
- GeometryDrawing.cs
- KerberosSecurityTokenProvider.cs
- CLRBindingWorker.cs
- lengthconverter.cs
- LinkLabelLinkClickedEvent.cs
- DataRecordInternal.cs
- CompilerError.cs
- ClientProxyGenerator.cs
- DocumentSchemaValidator.cs
- XamlReaderHelper.cs
- PartialCachingControl.cs
- WebReferenceOptions.cs
- PrimaryKeyTypeConverter.cs
- ImageDesigner.cs
- SimplePropertyEntry.cs
- SqlOuterApplyReducer.cs
- EdmItemCollection.cs
- CookieParameter.cs
- DataGridViewElement.cs
- GiveFeedbackEventArgs.cs