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
- UpdateCommand.cs
- LogEntrySerializationException.cs
- DispatchChannelSink.cs
- FontDriver.cs
- StringFormat.cs
- SmiXetterAccessMap.cs
- ConnectionManagementSection.cs
- ThrowHelper.cs
- ToolStripMenuItem.cs
- NetPipeSectionData.cs
- RtfNavigator.cs
- RuntimeConfigLKG.cs
- ToolboxItemCollection.cs
- WebPageTraceListener.cs
- XmlObjectSerializerContext.cs
- QilInvoke.cs
- BmpBitmapDecoder.cs
- _IPv4Address.cs
- DataRecord.cs
- DurableRuntimeValidator.cs
- GeneralTransformGroup.cs
- TTSEngineProxy.cs
- WizardSideBarListControlItemEventArgs.cs
- PersistNameAttribute.cs
- XmlObjectSerializerReadContext.cs
- TextTreeExtractElementUndoUnit.cs
- ImageCodecInfoPrivate.cs
- SqlLiftIndependentRowExpressions.cs
- XamlSerializerUtil.cs
- categoryentry.cs
- HttpResponseHeader.cs
- ZipIOFileItemStream.cs
- SecurityContext.cs
- TemplateControlCodeDomTreeGenerator.cs
- ObjectParameterCollection.cs
- Visitor.cs
- Normalization.cs
- thaishape.cs
- SimpleFieldTemplateFactory.cs
- HttpRequest.cs
- RecordConverter.cs
- UnknownWrapper.cs
- ColorTransformHelper.cs
- util.cs
- BuildResultCache.cs
- RijndaelManaged.cs
- TextTreePropertyUndoUnit.cs
- OdbcPermission.cs
- ModelFunctionTypeElement.cs
- AutomationElementIdentifiers.cs
- GridItem.cs
- ClusterRegistryConfigurationProvider.cs
- InlineObject.cs
- ExpressionBinding.cs
- IntegerValidatorAttribute.cs
- DataGridViewRow.cs
- Documentation.cs
- AutomationElementCollection.cs
- WebPartCancelEventArgs.cs
- DependencyPropertyValueSerializer.cs
- SymbolTable.cs
- IsolationInterop.cs
- compensatingcollection.cs
- InstanceHandleReference.cs
- DbConnectionPoolGroupProviderInfo.cs
- PartManifestEntry.cs
- DataGridAddNewRow.cs
- BindingExpression.cs
- PolicyManager.cs
- PrimitiveXmlSerializers.cs
- Popup.cs
- ADMembershipProvider.cs
- ConstructorExpr.cs
- ClientData.cs
- ScrollItemPattern.cs
- ECDiffieHellmanPublicKey.cs
- RegexStringValidator.cs
- SHA512.cs
- IgnoreDeviceFilterElementCollection.cs
- XslCompiledTransform.cs
- WebSysDisplayNameAttribute.cs
- HostingEnvironmentException.cs
- OutputWindow.cs
- DataControlCommands.cs
- DetailsViewDesigner.cs
- MruCache.cs
- DataGridLinkButton.cs
- Vector3D.cs
- PathData.cs
- PrintControllerWithStatusDialog.cs
- ParseHttpDate.cs
- EmptyWorkItem.cs
- CodeAttributeDeclarationCollection.cs
- PasswordTextContainer.cs
- SignatureToken.cs
- SqlProfileProvider.cs
- RoleService.cs
- SqlDataRecord.cs
- Predicate.cs
- WinEventWrap.cs