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
- TypeSemantics.cs
- PartitionedDataSource.cs
- RegexMatchCollection.cs
- BinaryObjectInfo.cs
- XmlFormatExtensionPointAttribute.cs
- ScriptReferenceBase.cs
- VersionConverter.cs
- XmlDocument.cs
- basenumberconverter.cs
- AggregateNode.cs
- BitmapMetadata.cs
- EntityTypeBase.cs
- InvariantComparer.cs
- HyperLinkStyle.cs
- XomlDesignerLoader.cs
- XmlElementAttribute.cs
- SimpleNameService.cs
- MaskedTextBox.cs
- SoapClientProtocol.cs
- ResXResourceSet.cs
- sqlstateclientmanager.cs
- TrackingMemoryStream.cs
- DataContractAttribute.cs
- ProfileProvider.cs
- Double.cs
- QueryContinueDragEventArgs.cs
- SystemUdpStatistics.cs
- WsatConfiguration.cs
- DBDataPermissionAttribute.cs
- PropertyMap.cs
- HostingEnvironmentWrapper.cs
- BitSet.cs
- RecordBuilder.cs
- recordstatescratchpad.cs
- Oid.cs
- TransformGroup.cs
- SessionStateModule.cs
- SqlMethods.cs
- TdsParameterSetter.cs
- EventQueueState.cs
- Renderer.cs
- ProfileSettings.cs
- TextSchema.cs
- OuterProxyWrapper.cs
- XmlReflectionImporter.cs
- IfJoinedCondition.cs
- TextReturnReader.cs
- ServiceDescriptions.cs
- RepeatBehavior.cs
- PriorityRange.cs
- SerializationSectionGroup.cs
- configsystem.cs
- WSDualHttpSecurityElement.cs
- FormatPage.cs
- OpCodes.cs
- MetadataArtifactLoaderResource.cs
- CodeGenerator.cs
- XmlAttribute.cs
- ControlPaint.cs
- ExtentKey.cs
- URI.cs
- HandleExceptionArgs.cs
- XmlJsonWriter.cs
- FormViewCommandEventArgs.cs
- SamlAuthorizationDecisionClaimResource.cs
- DataGridPagerStyle.cs
- OutputScopeManager.cs
- SystemIcmpV6Statistics.cs
- DataSetMappper.cs
- CatalogZone.cs
- OutputCacheSettings.cs
- SpellerStatusTable.cs
- RequestUriProcessor.cs
- SdlChannelSink.cs
- Group.cs
- TemplateXamlParser.cs
- BordersPage.cs
- PageStatePersister.cs
- BitSet.cs
- complextypematerializer.cs
- ListBox.cs
- DockAndAnchorLayout.cs
- srgsitem.cs
- Currency.cs
- FileStream.cs
- COM2ExtendedTypeConverter.cs
- OdbcStatementHandle.cs
- DataGridViewCellStyleChangedEventArgs.cs
- ValueType.cs
- SmtpFailedRecipientException.cs
- DesignerLabelAdapter.cs
- iisPickupDirectory.cs
- LinkLabel.cs
- WsdlBuildProvider.cs
- SqlAggregateChecker.cs
- FixedDSBuilder.cs
- ChineseLunisolarCalendar.cs
- JsonReaderDelegator.cs
- XmlEventCache.cs
- DateTimeOffset.cs