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
- SQLConvert.cs
- AssemblyName.cs
- _ConnectOverlappedAsyncResult.cs
- SafeThreadHandle.cs
- DeobfuscatingStream.cs
- SqlServices.cs
- RijndaelManagedTransform.cs
- CodeGenerator.cs
- ColorTransform.cs
- DataControlFieldHeaderCell.cs
- StructuralObject.cs
- DrawingState.cs
- AuthorizationRule.cs
- SectionXmlInfo.cs
- RangeBase.cs
- CodeTypeDeclaration.cs
- CallContext.cs
- SafeProcessHandle.cs
- RtfToken.cs
- Int64AnimationBase.cs
- FieldNameLookup.cs
- StrokeCollection2.cs
- CompiledQueryCacheKey.cs
- NavigationEventArgs.cs
- PathGeometry.cs
- Vars.cs
- UnsafeNativeMethodsMilCoreApi.cs
- SoapMessage.cs
- Composition.cs
- TableTextElementCollectionInternal.cs
- StylusTip.cs
- PolicyStatement.cs
- EntityDataSourceStatementEditorForm.cs
- SafeRightsManagementQueryHandle.cs
- TraceLevelStore.cs
- HtmlButton.cs
- AnnotationAdorner.cs
- Rule.cs
- DocumentOrderQuery.cs
- ItemCheckedEvent.cs
- PassportAuthenticationModule.cs
- DataGridViewCellLinkedList.cs
- validationstate.cs
- AssemblyGen.cs
- MailDefinition.cs
- ResourceFallbackManager.cs
- ThaiBuddhistCalendar.cs
- ShapingEngine.cs
- TraceFilter.cs
- FilteredReadOnlyMetadataCollection.cs
- SmtpSpecifiedPickupDirectoryElement.cs
- TabControl.cs
- StorageEntityTypeMapping.cs
- IOException.cs
- GrammarBuilderBase.cs
- ClientTargetSection.cs
- WebFormsRootDesigner.cs
- WebPartsPersonalization.cs
- ImmComposition.cs
- ReadOnlyCollectionBase.cs
- SqlDataSourceEnumerator.cs
- EntitySetBase.cs
- EastAsianLunisolarCalendar.cs
- XmlTypeAttribute.cs
- ScriptManager.cs
- TransferMode.cs
- ObjectDataProvider.cs
- TaskFileService.cs
- EdmScalarPropertyAttribute.cs
- BindingGroup.cs
- PersonalizationProvider.cs
- ChannelRequirements.cs
- wmiprovider.cs
- DiscoveryRequestHandler.cs
- Errors.cs
- ButtonBase.cs
- DataGridViewAutoSizeColumnsModeEventArgs.cs
- SerializerDescriptor.cs
- AttachedProperty.cs
- ListParagraph.cs
- SqlDataSourceSelectingEventArgs.cs
- LineServicesRun.cs
- Cursors.cs
- RtType.cs
- OdbcUtils.cs
- RadioButtonBaseAdapter.cs
- HijriCalendar.cs
- CalendarDataBindingHandler.cs
- TrustLevelCollection.cs
- SerializerWriterEventHandlers.cs
- HttpWrapper.cs
- Vector3DAnimationUsingKeyFrames.cs
- ConfigsHelper.cs
- Registry.cs
- DispatcherOperation.cs
- ExpressionEditorAttribute.cs
- IconBitmapDecoder.cs
- ActivityDesignerResources.cs
- ApplicationActivator.cs
- ItemCheckEvent.cs