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
- ContainerUIElement3D.cs
- MbpInfo.cs
- ScrollViewerAutomationPeer.cs
- SystemInfo.cs
- TreeView.cs
- ObjectStateEntry.cs
- WhitespaceSignificantCollectionAttribute.cs
- designeractionbehavior.cs
- Point4D.cs
- EncodingInfo.cs
- MediaPlayer.cs
- InvalidPrinterException.cs
- EDesignUtil.cs
- BindingOperations.cs
- ToolBarOverflowPanel.cs
- CodeAttributeDeclaration.cs
- shaperfactoryquerycacheentry.cs
- ListViewDataItem.cs
- Configuration.cs
- RecognizerBase.cs
- AuthenticatedStream.cs
- WindowsGraphics.cs
- PathFigure.cs
- CreateUserErrorEventArgs.cs
- CommonGetThemePartSize.cs
- TypefaceMap.cs
- VectorAnimation.cs
- WindowsIPAddress.cs
- _HTTPDateParse.cs
- PrintDocument.cs
- Visual3D.cs
- StyleCollectionEditor.cs
- HelpKeywordAttribute.cs
- ReachUIElementCollectionSerializerAsync.cs
- Transform3D.cs
- DataRecordObjectView.cs
- ExtendedTransformFactory.cs
- ComPlusAuthorization.cs
- SessionStateSection.cs
- Property.cs
- Simplifier.cs
- ProcessHostServerConfig.cs
- mediapermission.cs
- WindowsUserNameSecurityTokenAuthenticator.cs
- DataGridToolTip.cs
- followingsibling.cs
- DateTimeFormatInfo.cs
- EntityDataSourceWrapperCollection.cs
- SmiRequestExecutor.cs
- GroupBoxRenderer.cs
- XmlSchemaInferenceException.cs
- LongValidator.cs
- ProfessionalColors.cs
- IndexedString.cs
- UriTemplateQueryValue.cs
- CodePageUtils.cs
- EdmMember.cs
- PropertyMapper.cs
- HtmlGenericControl.cs
- Rect.cs
- PackageRelationshipSelector.cs
- InheritanceService.cs
- DataGridViewCellParsingEventArgs.cs
- KnownTypesProvider.cs
- InlineUIContainer.cs
- FacetDescriptionElement.cs
- ListSourceHelper.cs
- ScriptComponentDescriptor.cs
- RootProfilePropertySettingsCollection.cs
- RoutedEventHandlerInfo.cs
- QuadraticBezierSegment.cs
- IImplicitResourceProvider.cs
- ObjectResult.cs
- __Error.cs
- TreeNodeBinding.cs
- DecimalKeyFrameCollection.cs
- ExpressionBuilderCollection.cs
- ShaderEffect.cs
- QueryValue.cs
- WindowProviderWrapper.cs
- CapiNative.cs
- DashStyles.cs
- Parser.cs
- MultiTouchSystemGestureLogic.cs
- ColumnBinding.cs
- EntityDataSourceDataSelection.cs
- DrawingImage.cs
- CheckBoxFlatAdapter.cs
- TriggerAction.cs
- ScrollEventArgs.cs
- OutgoingWebResponseContext.cs
- SizeAnimation.cs
- Pens.cs
- _ScatterGatherBuffers.cs
- DesignerHierarchicalDataSourceView.cs
- EntityDesignerUtils.cs
- XXXOnTypeBuilderInstantiation.cs
- PageRequestManager.cs
- InputReferenceExpression.cs
- InstanceDataCollection.cs