Code:
/ Net / Net / 3.5.50727.3053 / DEVDIV / depot / DevDiv / releases / whidbey / netfxsp / 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
- MarginCollapsingState.cs
- xmlformatgeneratorstatics.cs
- MasterPageCodeDomTreeGenerator.cs
- StoreContentChangedEventArgs.cs
- RegistrySecurity.cs
- LocatorGroup.cs
- XmlSchemaInferenceException.cs
- SemanticAnalyzer.cs
- mediaeventargs.cs
- SystemPens.cs
- NumberFunctions.cs
- DescendentsWalkerBase.cs
- Brushes.cs
- ConfigurationManagerHelperFactory.cs
- DataGridViewCellStyle.cs
- TdsParserStateObject.cs
- DynamicMetaObjectBinder.cs
- Solver.cs
- SHA512Managed.cs
- ToolStripDropDownItem.cs
- AttachmentCollection.cs
- CompilerParameters.cs
- CodeConstructor.cs
- SystemInfo.cs
- ContextProperty.cs
- SoapTypeAttribute.cs
- XmlObjectSerializerReadContextComplexJson.cs
- ConfigurationErrorsException.cs
- GeneratedView.cs
- Function.cs
- DataRelationPropertyDescriptor.cs
- Panel.cs
- NativeMethods.cs
- XmlNamespaceManager.cs
- BridgeDataRecord.cs
- SmiEventStream.cs
- ResolveMatchesCD1.cs
- ConfigXmlWhitespace.cs
- TypefaceCollection.cs
- OpCodes.cs
- UrlAuthFailedErrorFormatter.cs
- IntSecurity.cs
- ParsedAttributeCollection.cs
- ExpressionReplacer.cs
- ConfigurationValue.cs
- XmlFormatReaderGenerator.cs
- RichTextBoxConstants.cs
- DictionaryManager.cs
- InternalCache.cs
- SqlCharStream.cs
- TextProviderWrapper.cs
- DateTimeConstantAttribute.cs
- AnnotationMap.cs
- TypeConverterValueSerializer.cs
- Collection.cs
- COM2ExtendedTypeConverter.cs
- InputProcessorProfilesLoader.cs
- CachedPathData.cs
- ListManagerBindingsCollection.cs
- StateItem.cs
- MarkerProperties.cs
- SqlRowUpdatingEvent.cs
- TreeNodeClickEventArgs.cs
- NavigationProperty.cs
- CalculatedColumn.cs
- MenuScrollingVisibilityConverter.cs
- DataGridViewColumnConverter.cs
- WrappedIUnknown.cs
- HWStack.cs
- RequestQueryParser.cs
- SymLanguageType.cs
- DocumentPageTextView.cs
- XmlSchemaSubstitutionGroup.cs
- CryptoHandle.cs
- ScriptingRoleServiceSection.cs
- SqlVisitor.cs
- PrinterSettings.cs
- VBCodeProvider.cs
- RepeatBehavior.cs
- UITypeEditors.cs
- ConfigurationSectionCollection.cs
- RequestCacheValidator.cs
- EncodingDataItem.cs
- SymmetricCryptoHandle.cs
- AnnotationAuthorChangedEventArgs.cs
- UidManager.cs
- EnvironmentPermission.cs
- Permission.cs
- RowType.cs
- AssemblyNameUtility.cs
- SqlCacheDependencyDatabase.cs
- BevelBitmapEffect.cs
- DoubleConverter.cs
- ChannelManager.cs
- EmptyStringExpandableObjectConverter.cs
- AssertValidation.cs
- DefaultMemberAttribute.cs
- DrawingDrawingContext.cs
- LocalBuilder.cs
- Fonts.cs