Code:
/ Dotnetfx_Vista_SP2 / Dotnetfx_Vista_SP2 / 8.0.50727.4016 / DEVDIV / depot / DevDiv / releases / whidbey / NetFxQFE / 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
- OutputCacheSettingsSection.cs
- IDispatchConstantAttribute.cs
- RangeContentEnumerator.cs
- CatalogZoneAutoFormat.cs
- SQLDecimalStorage.cs
- DataGridViewTopRowAccessibleObject.cs
- PointAnimationBase.cs
- RootProfilePropertySettingsCollection.cs
- OrderedHashRepartitionEnumerator.cs
- StringBlob.cs
- ReadOnlyHierarchicalDataSource.cs
- ResourceReferenceExpressionConverter.cs
- LongValidator.cs
- XmlSchemaSet.cs
- ObfuscationAttribute.cs
- ButtonColumn.cs
- CellCreator.cs
- _ProxyChain.cs
- OdbcErrorCollection.cs
- OlePropertyStructs.cs
- HealthMonitoringSection.cs
- Content.cs
- XmlDataSourceNodeDescriptor.cs
- PrinterUnitConvert.cs
- LinqDataView.cs
- BindableAttribute.cs
- TextServicesLoader.cs
- Vector3D.cs
- TraceInternal.cs
- FixedSOMSemanticBox.cs
- DBSchemaRow.cs
- Pair.cs
- ProcessingInstructionAction.cs
- CompositionTarget.cs
- XmlSchemaSubstitutionGroup.cs
- SqlLiftIndependentRowExpressions.cs
- NativeMethodsCLR.cs
- XmlSchemaExporter.cs
- StrokeCollection2.cs
- ItemDragEvent.cs
- ImageClickEventArgs.cs
- ToolStripSettings.cs
- X509Certificate.cs
- Graph.cs
- SqlMethodAttribute.cs
- LinqDataSourceDisposeEventArgs.cs
- DoubleAnimationBase.cs
- SignedXmlDebugLog.cs
- QueryInterceptorAttribute.cs
- VisualBasicSettingsHandler.cs
- MDIControlStrip.cs
- TraceLevelStore.cs
- UiaCoreApi.cs
- SqlRetyper.cs
- CodeAccessSecurityEngine.cs
- Button.cs
- RC2.cs
- TypeExtensionConverter.cs
- ContextBase.cs
- CommunicationObject.cs
- HtmlInputHidden.cs
- _ListenerRequestStream.cs
- XmlSchemaValidationException.cs
- SmiContextFactory.cs
- BreakRecordTable.cs
- UnsafeNativeMethods.cs
- ReferenceAssemblyAttribute.cs
- RTLAwareMessageBox.cs
- FileDialogCustomPlacesCollection.cs
- SimpleBitVector32.cs
- Lease.cs
- FileLevelControlBuilderAttribute.cs
- URLMembershipCondition.cs
- loginstatus.cs
- CheckBoxStandardAdapter.cs
- XmlIncludeAttribute.cs
- MessageBox.cs
- FloaterParaClient.cs
- DataConnectionHelper.cs
- XdrBuilder.cs
- DynamicValueConverter.cs
- FacetChecker.cs
- LeaseManager.cs
- BufferedOutputStream.cs
- ProviderUtil.cs
- FileSystemInfo.cs
- SqlMethods.cs
- ToolStripDropTargetManager.cs
- ServiceNameCollection.cs
- HttpRequest.cs
- EventLogPermission.cs
- TabRenderer.cs
- ConfigUtil.cs
- SqlSupersetValidator.cs
- Nullable.cs
- SymmetricKeyWrap.cs
- ContextInformation.cs
- PassportAuthenticationModule.cs
- TdsParserStaticMethods.cs
- CommonGetThemePartSize.cs