Code:
/ 4.0 / 4.0 / DEVDIV_TFS / Dev10 / Releases / RTMRel / ndp / fx / src / Net / System / Net / _CookieModule.cs / 1305376 / _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.GetRemoteResourceUri(), 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.GetRemoteResourceUri(), 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
- SqlReferenceCollection.cs
- ImageSource.cs
- ServiceOperationWrapper.cs
- Deflater.cs
- ISO2022Encoding.cs
- RightsManagementSuppressedStream.cs
- TextShapeableCharacters.cs
- StretchValidation.cs
- FilterQueryOptionExpression.cs
- OdbcInfoMessageEvent.cs
- AccessViolationException.cs
- webclient.cs
- Quaternion.cs
- Point.cs
- SystemFonts.cs
- Base64Stream.cs
- BinHexEncoding.cs
- srgsitem.cs
- DesignerWidgets.cs
- ZipFileInfo.cs
- StreamGeometryContext.cs
- SpecialNameAttribute.cs
- TypeUsage.cs
- SoapInteropTypes.cs
- PhoneCall.cs
- ErrorFormatterPage.cs
- CustomAttributeFormatException.cs
- ChildrenQuery.cs
- IdentityReference.cs
- ActivationServices.cs
- EmptyEnumerable.cs
- ByteRangeDownloader.cs
- SharedPerformanceCounter.cs
- Light.cs
- PageAsyncTask.cs
- mactripleDES.cs
- LocalizedNameDescriptionPair.cs
- ToolStripComboBox.cs
- LayoutEditorPart.cs
- Cell.cs
- CfgParser.cs
- CollectionEditor.cs
- PasswordTextNavigator.cs
- MenuItemStyleCollection.cs
- StructuredType.cs
- HtmlInputCheckBox.cs
- SignatureToken.cs
- WebPartDescriptionCollection.cs
- GiveFeedbackEventArgs.cs
- EntityContainer.cs
- Filter.cs
- ExpressionNode.cs
- TrackingServices.cs
- coordinatorfactory.cs
- QilFactory.cs
- DBDataPermission.cs
- HttpConfigurationContext.cs
- HttpCapabilitiesBase.cs
- Stacktrace.cs
- PageThemeParser.cs
- MULTI_QI.cs
- ToolBar.cs
- TagPrefixInfo.cs
- XPathItem.cs
- ConfigurationException.cs
- BaseAsyncResult.cs
- QilFunction.cs
- TextReturnReader.cs
- WithStatement.cs
- GeometryCombineModeValidation.cs
- TdsParserHelperClasses.cs
- WebPartManagerInternals.cs
- List.cs
- OdbcFactory.cs
- BaseDataList.cs
- XPathNodeHelper.cs
- SignatureHelper.cs
- DrawingContextDrawingContextWalker.cs
- BuildResultCache.cs
- connectionpool.cs
- DataGridViewColumnCollectionDialog.cs
- Roles.cs
- InstanceLockException.cs
- RSAPKCS1KeyExchangeDeformatter.cs
- HierarchicalDataTemplate.cs
- HtmlProps.cs
- ForeignKeyConstraint.cs
- EventPropertyMap.cs
- FreezableOperations.cs
- JulianCalendar.cs
- SynthesizerStateChangedEventArgs.cs
- BitmapPalette.cs
- ActiveXSite.cs
- CompletedAsyncResult.cs
- PieceDirectory.cs
- BitmapEffectInputData.cs
- FontFamilyIdentifier.cs
- PinnedBufferMemoryStream.cs
- ProviderUtil.cs
- CommandBinding.cs