Code:
/ Dotnetfx_Vista_SP2 / Dotnetfx_Vista_SP2 / 8.0.50727.4016 / DEVDIV / depot / DevDiv / releases / whidbey / NetFxQFE / 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
- ComponentResourceKey.cs
- QuestionEventArgs.cs
- StateRuntime.cs
- Polyline.cs
- CryptoKeySecurity.cs
- SystemColors.cs
- BitmapEncoder.cs
- DataGridViewCellValueEventArgs.cs
- XslException.cs
- XmlSchemaSimpleContentRestriction.cs
- streamingZipPartStream.cs
- TransformationRules.cs
- EmbeddedMailObject.cs
- WebPartChrome.cs
- BinaryParser.cs
- ListManagerBindingsCollection.cs
- ApplicationHost.cs
- CaseInsensitiveOrdinalStringComparer.cs
- CTreeGenerator.cs
- PermissionListSet.cs
- HighlightComponent.cs
- TextBlockAutomationPeer.cs
- HierarchicalDataTemplate.cs
- ToolStripItemRenderEventArgs.cs
- CharacterString.cs
- CqlLexer.cs
- DocumentEventArgs.cs
- XmlStreamStore.cs
- OutputCacheSection.cs
- DetectEofStream.cs
- WorkflowOperationBehavior.cs
- SqlUtils.cs
- HMACSHA1.cs
- DataBoundControlHelper.cs
- Line.cs
- XslCompiledTransform.cs
- SrgsToken.cs
- ShutDownListener.cs
- ExeContext.cs
- WebPartHelpVerb.cs
- DataFormats.cs
- EncryptedType.cs
- DataSourceIDConverter.cs
- FixedSOMImage.cs
- SoapSchemaExporter.cs
- PreApplicationStartMethodAttribute.cs
- PostBackOptions.cs
- ColorComboBox.cs
- SqlDataSourceFilteringEventArgs.cs
- ColorConvertedBitmap.cs
- Html32TextWriter.cs
- GraphicsPath.cs
- ByteStorage.cs
- ResourcesBuildProvider.cs
- PixelFormats.cs
- ListManagerBindingsCollection.cs
- Ops.cs
- ScriptManager.cs
- ChtmlTextWriter.cs
- RijndaelManaged.cs
- CollectionViewGroupRoot.cs
- ConnectorDragDropGlyph.cs
- Hex.cs
- DataGridViewTextBoxEditingControl.cs
- LinqDataSourceEditData.cs
- DataTransferEventArgs.cs
- MultitargetingHelpers.cs
- FamilyMapCollection.cs
- MergePropertyDescriptor.cs
- ContractAdapter.cs
- FollowerQueueCreator.cs
- Profiler.cs
- DictionaryEntry.cs
- FixUp.cs
- ViewCellRelation.cs
- DataGridView.cs
- SchemaMapping.cs
- FacetDescriptionElement.cs
- MenuItemStyleCollection.cs
- ChtmlTextWriter.cs
- ContextMarshalException.cs
- UrlMappingsSection.cs
- ViewPort3D.cs
- DataGridHeaderBorder.cs
- HostingEnvironmentSection.cs
- Ipv6Element.cs
- LexicalChunk.cs
- DiagnosticsConfiguration.cs
- MergeFilterQuery.cs
- InvalidComObjectException.cs
- StringSource.cs
- HealthMonitoringSectionHelper.cs
- OperationCanceledException.cs
- XmlSchemaException.cs
- RolePrincipal.cs
- ExceptionValidationRule.cs
- UriTemplateEquivalenceComparer.cs
- serverconfig.cs
- ServiceModelConfiguration.cs
- ReceiveCompletedEventArgs.cs