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
- RecognizerStateChangedEventArgs.cs
- ApplicationContext.cs
- PrivateFontCollection.cs
- HttpWriter.cs
- ResourceIDHelper.cs
- ServerReliableChannelBinder.cs
- DataGridRowHeaderAutomationPeer.cs
- Deflater.cs
- StrokeNode.cs
- NameValuePair.cs
- CursorConverter.cs
- SafeHandles.cs
- DataSetFieldSchema.cs
- RegexReplacement.cs
- HttpStaticObjectsCollectionWrapper.cs
- TargetInvocationException.cs
- UseAttributeSetsAction.cs
- URLString.cs
- ToolStripItemClickedEventArgs.cs
- ModelUIElement3D.cs
- BitVector32.cs
- TransactionValidationBehavior.cs
- XmlTextEncoder.cs
- _ListenerRequestStream.cs
- ShaperBuffers.cs
- StringFormat.cs
- ResourceExpressionBuilder.cs
- CertificateElement.cs
- GridViewActionList.cs
- VectorCollection.cs
- LinqDataSourceStatusEventArgs.cs
- XmlSchemaSimpleTypeUnion.cs
- CssClassPropertyAttribute.cs
- LayoutInformation.cs
- UndirectedGraph.cs
- ServiceNameCollection.cs
- ObjectDataSourceEventArgs.cs
- StaticTextPointer.cs
- FreezableDefaultValueFactory.cs
- EditorZoneBase.cs
- XmlSchemaAttribute.cs
- CryptoKeySecurity.cs
- BinaryObjectReader.cs
- HwndHost.cs
- ResizingMessageFilter.cs
- TargetFrameworkAttribute.cs
- XmlDocument.cs
- ReadingWritingEntityEventArgs.cs
- PingReply.cs
- DataSetMappper.cs
- ColorBlend.cs
- BitmapEffectRenderDataResource.cs
- URLEditor.cs
- ProfilePropertySettingsCollection.cs
- GeometryDrawing.cs
- IxmlLineInfo.cs
- XmlNamespaceManager.cs
- CompiledQuery.cs
- UshortList2.cs
- HtmlElement.cs
- Image.cs
- Cursor.cs
- RenderData.cs
- WindowsEditBoxRange.cs
- FrameworkTextComposition.cs
- RequestQueue.cs
- ReadWriteObjectLock.cs
- IPPacketInformation.cs
- NativeMethods.cs
- Operator.cs
- TypeInformation.cs
- ProfileGroupSettings.cs
- FileReader.cs
- XmlEventCache.cs
- Literal.cs
- NamedPipeHostedTransportConfiguration.cs
- BindableTemplateBuilder.cs
- Comparer.cs
- NTAccount.cs
- DeviceFiltersSection.cs
- StylusCaptureWithinProperty.cs
- FontDriver.cs
- XsdDataContractExporter.cs
- WebPartConnectionsConfigureVerb.cs
- CodeEventReferenceExpression.cs
- TerminateDesigner.cs
- QuaternionAnimation.cs
- AliasGenerator.cs
- Msmq.cs
- SspiNegotiationTokenProvider.cs
- PixelFormat.cs
- RectValueSerializer.cs
- WebPartChrome.cs
- SecurityContextSecurityTokenResolver.cs
- NetworkStream.cs
- DesignTimeData.cs
- MetadataUtil.cs
- PrePrepareMethodAttribute.cs
- TextSegment.cs
- BinaryFormatterWriter.cs