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
- SspiNegotiationTokenProviderState.cs
- URLMembershipCondition.cs
- HwndTarget.cs
- TextLineResult.cs
- ComPlusAuthorization.cs
- DataGridViewSelectedRowCollection.cs
- ComIntegrationManifestGenerator.cs
- Type.cs
- Stylesheet.cs
- ObjectTokenCategory.cs
- WinEventQueueItem.cs
- GregorianCalendarHelper.cs
- CodeTypeMemberCollection.cs
- Region.cs
- OperatorExpressions.cs
- InputBuffer.cs
- FamilyTypeface.cs
- WorkflowRuntime.cs
- ScrollEventArgs.cs
- TemplateBamlTreeBuilder.cs
- XmlSchemaFacet.cs
- SharedUtils.cs
- CircleHotSpot.cs
- RelationshipType.cs
- TypeDependencyAttribute.cs
- SemaphoreSecurity.cs
- EntityDataSourceContextCreatedEventArgs.cs
- BindingExpressionUncommonField.cs
- DirectionalLight.cs
- SpeechDetectedEventArgs.cs
- HttpCookie.cs
- TableCellsCollectionEditor.cs
- XmlCustomFormatter.cs
- ConfigXmlCDataSection.cs
- EastAsianLunisolarCalendar.cs
- PartBasedPackageProperties.cs
- DeclaredTypeValidatorAttribute.cs
- AvTraceFormat.cs
- SystemIPv4InterfaceProperties.cs
- QilStrConcat.cs
- PropertyGeneratedEventArgs.cs
- handlecollector.cs
- InkCanvasInnerCanvas.cs
- Font.cs
- BinaryConverter.cs
- DataSourceXmlTextReader.cs
- DataTableNameHandler.cs
- DataGridViewLayoutData.cs
- TransformCollection.cs
- GeneralTransform.cs
- PointHitTestParameters.cs
- SQLUtility.cs
- XmlReflectionImporter.cs
- SafeProcessHandle.cs
- HtmlTextArea.cs
- HMACSHA256.cs
- SecurityCriticalDataForSet.cs
- ZipPackagePart.cs
- JournalEntry.cs
- AsnEncodedData.cs
- XmlReader.cs
- ResourceContainer.cs
- ExpandSegmentCollection.cs
- ListItemsPage.cs
- X509Extension.cs
- ProfilePropertyMetadata.cs
- Parallel.cs
- Parameter.cs
- PackagePart.cs
- TypedTableHandler.cs
- Dynamic.cs
- XmlSchemaAppInfo.cs
- VariableQuery.cs
- ChangePasswordAutoFormat.cs
- FloaterParagraph.cs
- MessageBox.cs
- ServerProtocol.cs
- XmlIncludeAttribute.cs
- ContextItemManager.cs
- EntityWithChangeTrackerStrategy.cs
- SoapFault.cs
- StrongNameHelpers.cs
- ClientSideQueueItem.cs
- CalendarButton.cs
- TreeNodeBinding.cs
- Label.cs
- XsdCachingReader.cs
- Membership.cs
- SafeNativeMethods.cs
- DataControlField.cs
- LinkedResource.cs
- ApplicationHost.cs
- TextDecorations.cs
- TableLayoutStyle.cs
- TransformerTypeCollection.cs
- PropertyReferenceSerializer.cs
- TemplateControlCodeDomTreeGenerator.cs
- WindowsRichEditRange.cs
- PenContexts.cs
- SpellCheck.cs