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
- PnrpPermission.cs
- WaitHandle.cs
- FixedSOMImage.cs
- UnsafeNativeMethodsCLR.cs
- Stopwatch.cs
- CustomWebEventKey.cs
- CopyEncoder.cs
- ActivationArguments.cs
- HttpProfileGroupBase.cs
- SafeSystemMetrics.cs
- CodeGenerator.cs
- MaskDescriptors.cs
- WindowHideOrCloseTracker.cs
- TypeUtil.cs
- BooleanAnimationUsingKeyFrames.cs
- embossbitmapeffect.cs
- XmlLoader.cs
- EventSinkHelperWriter.cs
- BlurEffect.cs
- IntegerFacetDescriptionElement.cs
- DbParameterCollectionHelper.cs
- OutputBuffer.cs
- WinEventHandler.cs
- ExpandSegment.cs
- AstTree.cs
- XNodeNavigator.cs
- DataBoundControlHelper.cs
- DependencyPropertyHelper.cs
- Model3D.cs
- RegexRunner.cs
- ReflectPropertyDescriptor.cs
- DataKeyCollection.cs
- AutomationProperty.cs
- PersonalizationAdministration.cs
- DataServiceQuery.cs
- File.cs
- HttpConfigurationSystem.cs
- TransactionChannelFactory.cs
- VirtualPathData.cs
- PartialArray.cs
- Vector3DAnimationBase.cs
- HwndProxyElementProvider.cs
- XmlAttributeAttribute.cs
- SocketException.cs
- PropertyIdentifier.cs
- DateTimeOffsetConverter.cs
- SettingsAttributeDictionary.cs
- StylusTip.cs
- ClientData.cs
- TreeNodeCollection.cs
- XmlBufferReader.cs
- _NegoStream.cs
- Component.cs
- BuilderInfo.cs
- IndentTextWriter.cs
- WebScriptMetadataMessageEncodingBindingElement.cs
- FactoryGenerator.cs
- NamedObject.cs
- ByteConverter.cs
- DeleteIndexBinder.cs
- PostBackOptions.cs
- Helpers.cs
- SymLanguageType.cs
- IndentTextWriter.cs
- DiagnosticTrace.cs
- InputLanguageSource.cs
- Filter.cs
- mil_commands.cs
- ScaleTransform.cs
- RequestCacheManager.cs
- RoutingExtensionElement.cs
- OracleTransaction.cs
- XmlBinaryReader.cs
- HeaderedContentControl.cs
- EdmValidator.cs
- ChangeBlockUndoRecord.cs
- UnsafeNativeMethodsTablet.cs
- SkinBuilder.cs
- AsyncStreamReader.cs
- SupportsEventValidationAttribute.cs
- MailSettingsSection.cs
- DoubleLinkList.cs
- StrokeCollection2.cs
- ArrayElementGridEntry.cs
- SqlGatherConsumedAliases.cs
- SqlConnection.cs
- Bidi.cs
- ConnectivityStatus.cs
- DataGridViewImageColumn.cs
- PropertyGeneratedEventArgs.cs
- ColumnWidthChangedEvent.cs
- LazyTextWriterCreator.cs
- XmlSchemaObjectCollection.cs
- CompModSwitches.cs
- SoapDocumentServiceAttribute.cs
- HtmlWindow.cs
- SrgsItemList.cs
- LinkConverter.cs
- UndoManager.cs
- XmlElementAttributes.cs