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
- MimeObjectFactory.cs
- safelink.cs
- Utilities.cs
- TypePropertyEditor.cs
- SpotLight.cs
- BrowserCapabilitiesCompiler.cs
- DataBoundControl.cs
- UnicastIPAddressInformationCollection.cs
- LinkedResource.cs
- SecureStringHasher.cs
- ExpressionNode.cs
- FileInfo.cs
- DifferencingCollection.cs
- PointAnimationUsingKeyFrames.cs
- TemplateInstanceAttribute.cs
- DataSysAttribute.cs
- XmlSerializerAssemblyAttribute.cs
- DocumentPage.cs
- EntityContainer.cs
- SignatureResourcePool.cs
- ObjectAnimationBase.cs
- DragDrop.cs
- Accessible.cs
- DataColumnPropertyDescriptor.cs
- ArrayWithOffset.cs
- DBSqlParserColumn.cs
- SqlCacheDependency.cs
- ComplexObject.cs
- MimeReturn.cs
- UpdateException.cs
- TypeForwardedToAttribute.cs
- WebPart.cs
- ParseChildrenAsPropertiesAttribute.cs
- EmptyControlCollection.cs
- PageThemeBuildProvider.cs
- SubclassTypeValidatorAttribute.cs
- XmlObjectSerializer.cs
- ElementUtil.cs
- IntSecurity.cs
- __Error.cs
- ReflectionUtil.cs
- Processor.cs
- EntityParameter.cs
- ToolstripProfessionalRenderer.cs
- unsafeIndexingFilterStream.cs
- AutoResetEvent.cs
- DesignerOptionService.cs
- DescriptionAttribute.cs
- HtmlShim.cs
- AuthorizationRule.cs
- ColorMap.cs
- MetadataPropertyCollection.cs
- MenuItemBindingCollection.cs
- DotExpr.cs
- RSAOAEPKeyExchangeDeformatter.cs
- DataControlCommands.cs
- KeyValueSerializer.cs
- DataListItemEventArgs.cs
- ListViewContainer.cs
- SoundPlayer.cs
- GeneralTransform3DTo2DTo3D.cs
- ImplicitInputBrush.cs
- CrossSiteScriptingValidation.cs
- HMACSHA1.cs
- Vector3DCollectionConverter.cs
- LineInfo.cs
- EncodingTable.cs
- ControlValuePropertyAttribute.cs
- UndirectedGraph.cs
- Vector3D.cs
- XmlSchemaSimpleContent.cs
- VisualStyleTypesAndProperties.cs
- SpeechSeg.cs
- MonthCalendarDesigner.cs
- BindingContext.cs
- DataSourceControlBuilder.cs
- VScrollProperties.cs
- SQLDecimalStorage.cs
- ActivityExecutorSurrogate.cs
- AppDomainCompilerProxy.cs
- DataServiceKeyAttribute.cs
- CodeTypeOfExpression.cs
- CachingHintValidation.cs
- Parser.cs
- UnsafeNativeMethodsPenimc.cs
- UnmanagedMemoryAccessor.cs
- OutputCacheProfileCollection.cs
- ISAPIWorkerRequest.cs
- ComponentSerializationService.cs
- VisualStyleRenderer.cs
- PageCodeDomTreeGenerator.cs
- TraceEventCache.cs
- DataControlFieldHeaderCell.cs
- Base64Encoder.cs
- ResourceReferenceExpression.cs
- HtmlTextArea.cs
- FixedFindEngine.cs
- ColorMatrix.cs
- PolicyManager.cs
- designeractionlistschangedeventargs.cs