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
- StandardCommands.cs
- GridItem.cs
- CompositeFontParser.cs
- HtmlToClrEventProxy.cs
- OrderPreservingPipeliningMergeHelper.cs
- unsafenativemethodstextservices.cs
- Console.cs
- validationstate.cs
- ProcessModule.cs
- CanExecuteRoutedEventArgs.cs
- CssStyleCollection.cs
- AppDomainFactory.cs
- X509ChainElement.cs
- GACMembershipCondition.cs
- AssociationTypeEmitter.cs
- SqlFunctionAttribute.cs
- PageAsyncTask.cs
- Set.cs
- SecurityDocument.cs
- ListChangedEventArgs.cs
- ButtonStandardAdapter.cs
- PlainXmlDeserializer.cs
- CmsInterop.cs
- DirectoryObjectSecurity.cs
- BitmapEffectGroup.cs
- StylusPointProperty.cs
- ListControl.cs
- ErrorTableItemStyle.cs
- TemplateEditingService.cs
- PrivilegedConfigurationManager.cs
- SortQueryOperator.cs
- namescope.cs
- FrameworkElement.cs
- EntitySqlQueryState.cs
- LogExtentCollection.cs
- NotificationContext.cs
- TypeBuilder.cs
- WebPartPersonalization.cs
- QuerySettings.cs
- MsiStyleLogWriter.cs
- ErrorActivity.cs
- AmbientValueAttribute.cs
- DataGridViewTopLeftHeaderCell.cs
- Icon.cs
- TextRange.cs
- StickyNote.cs
- Site.cs
- Operators.cs
- ProfileService.cs
- SmtpNetworkElement.cs
- FactoryGenerator.cs
- WebControlAdapter.cs
- ReadOnlyDictionary.cs
- PrintPreviewGraphics.cs
- SqlReorderer.cs
- SiteMapNode.cs
- EntitySqlQueryCacheKey.cs
- MetafileEditor.cs
- sqlpipe.cs
- XmlSubtreeReader.cs
- PropertyIDSet.cs
- CancellationTokenRegistration.cs
- SyncMethodInvoker.cs
- SharedStatics.cs
- SourceLocation.cs
- SessionStateUtil.cs
- TraceFilter.cs
- unsafenativemethodsother.cs
- ValidateNames.cs
- EventEntry.cs
- SynchronizationLockException.cs
- SelectionList.cs
- ShellProvider.cs
- MsmqActivation.cs
- MenuAutomationPeer.cs
- MoveSizeWinEventHandler.cs
- XamlFilter.cs
- FtpRequestCacheValidator.cs
- NominalTypeEliminator.cs
- ResXBuildProvider.cs
- XhtmlBasicValidatorAdapter.cs
- TransportBindingElementImporter.cs
- XmlUTF8TextReader.cs
- CodeMemberField.cs
- InputReferenceExpression.cs
- CapabilitiesState.cs
- HierarchicalDataTemplate.cs
- TabletDeviceInfo.cs
- HtmlTableRow.cs
- XmlExceptionHelper.cs
- PolyLineSegment.cs
- CodeDOMUtility.cs
- CryptoStream.cs
- DoubleAnimationUsingPath.cs
- SessionStateUtil.cs
- HTMLTextWriter.cs
- XamlTypeMapper.cs
- SspiSecurityTokenProvider.cs
- Line.cs
- _NtlmClient.cs