Code:
/ Dotnetfx_Win7_3.5.1 / Dotnetfx_Win7_3.5.1 / 3.5.1 / DEVDIV / depot / DevDiv / releases / whidbey / NetFXspW7 / 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
- TransferRequestHandler.cs
- DataGridViewTextBoxColumn.cs
- RegisteredDisposeScript.cs
- Ipv6Element.cs
- ItemCheckedEvent.cs
- CFStream.cs
- ErrorProvider.cs
- cookiecontainer.cs
- LicenseException.cs
- _NestedMultipleAsyncResult.cs
- TypeLibConverter.cs
- DataControlLinkButton.cs
- RadioButtonPopupAdapter.cs
- BindingSourceDesigner.cs
- BinaryConverter.cs
- CompModSwitches.cs
- WpfSharedBamlSchemaContext.cs
- CodeGeneratorOptions.cs
- SmtpFailedRecipientException.cs
- DefaultValueConverter.cs
- EnumValidator.cs
- BackgroundFormatInfo.cs
- _ServiceNameStore.cs
- DoubleAnimation.cs
- TextFormatterContext.cs
- EventLevel.cs
- Pkcs7Signer.cs
- StringUtil.cs
- RepeaterItem.cs
- SmiRequestExecutor.cs
- SortAction.cs
- QilGenerator.cs
- TableSectionStyle.cs
- SqlUserDefinedTypeAttribute.cs
- DecimalConstantAttribute.cs
- CommandValueSerializer.cs
- XmlILIndex.cs
- BufferedWebEventProvider.cs
- WindowsButton.cs
- BufferBuilder.cs
- GeneratedContractType.cs
- DeferredReference.cs
- AjaxFrameworkAssemblyAttribute.cs
- activationcontext.cs
- SettingsPropertyWrongTypeException.cs
- DataView.cs
- ValidatorCompatibilityHelper.cs
- InstanceDataCollection.cs
- BamlLocalizer.cs
- ItemPager.cs
- MarshalByValueComponent.cs
- SqlTriggerContext.cs
- SQLBinary.cs
- LogStream.cs
- RecognizedPhrase.cs
- Matrix3DConverter.cs
- Literal.cs
- _AutoWebProxyScriptWrapper.cs
- FormatterServicesNoSerializableCheck.cs
- Walker.cs
- EditingScope.cs
- AuthenticationException.cs
- BindingGroup.cs
- Point3DAnimationBase.cs
- ConfigurationProperty.cs
- IgnoreSectionHandler.cs
- SettingsSection.cs
- DBSqlParserTableCollection.cs
- HMAC.cs
- UnsafeNativeMethods.cs
- XmlSchemaException.cs
- MultiPageTextView.cs
- KeyValuePairs.cs
- ContainerUIElement3D.cs
- WizardStepBase.cs
- SapiInterop.cs
- FontSource.cs
- NameSpaceEvent.cs
- DictionaryContent.cs
- DBCommandBuilder.cs
- SecurityUtils.cs
- ZipFileInfo.cs
- NavigateUrlConverter.cs
- AutomationElementCollection.cs
- EnumMemberAttribute.cs
- TextRange.cs
- ToolStripPanelRow.cs
- TextContainerChangedEventArgs.cs
- FunctionGenerator.cs
- WindowVisualStateTracker.cs
- RuleAttributes.cs
- FormViewCommandEventArgs.cs
- TypeCodeDomSerializer.cs
- UriWriter.cs
- BypassElementCollection.cs
- _NegotiateClient.cs
- StatusBarDesigner.cs
- MachineKey.cs
- XhtmlBasicImageAdapter.cs
- JsonQNameDataContract.cs