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
- DllNotFoundException.cs
- ACE.cs
- BaseConfigurationRecord.cs
- TextParagraphCache.cs
- ActionFrame.cs
- PropertyGeneratedEventArgs.cs
- LayoutTable.cs
- _AutoWebProxyScriptEngine.cs
- VersionedStream.cs
- SchemaAttDef.cs
- WindowsUserNameSecurityTokenAuthenticator.cs
- MetadataCacheItem.cs
- ProgressBarHighlightConverter.cs
- SystemColors.cs
- ContainerUIElement3D.cs
- BitmapData.cs
- AspNetSynchronizationContext.cs
- ToolStripLocationCancelEventArgs.cs
- TextContainer.cs
- PackageRelationshipCollection.cs
- NetworkInterface.cs
- RequestTimeoutManager.cs
- InvalidFilterCriteriaException.cs
- HTMLTagNameToTypeMapper.cs
- StringWriter.cs
- SqlUserDefinedAggregateAttribute.cs
- PropertyInformation.cs
- __FastResourceComparer.cs
- StylusPointDescription.cs
- EventMappingSettings.cs
- DeploymentSection.cs
- WorkflowQueue.cs
- graph.cs
- SmiContextFactory.cs
- XmlIlTypeHelper.cs
- FrameworkElementFactoryMarkupObject.cs
- UInt16Storage.cs
- WindowsGraphics2.cs
- CombinedHttpChannel.cs
- DataRelation.cs
- EncryptedType.cs
- WindowsListViewScroll.cs
- Collection.cs
- SqlNodeAnnotations.cs
- Debug.cs
- BamlLocalizer.cs
- TraceEventCache.cs
- Scheduler.cs
- TimeSpanConverter.cs
- BindingMemberInfo.cs
- XmlEntityReference.cs
- CaseStatement.cs
- DataContractAttribute.cs
- CodeTypeConstructor.cs
- ObjectTag.cs
- FixedPage.cs
- Psha1DerivedKeyGenerator.cs
- SqlAggregateChecker.cs
- DrawingContextDrawingContextWalker.cs
- EntityConnection.cs
- DirectoryInfo.cs
- NonBatchDirectoryCompiler.cs
- XPathChildIterator.cs
- DelegatingConfigHost.cs
- SqlMethodTransformer.cs
- ProcessHostServerConfig.cs
- ErrorWrapper.cs
- UTF8Encoding.cs
- ErrorStyle.cs
- QilGeneratorEnv.cs
- SqlProfileProvider.cs
- DataListCommandEventArgs.cs
- BitmapFrameEncode.cs
- VirtualPathProvider.cs
- InvalidAsynchronousStateException.cs
- RayMeshGeometry3DHitTestResult.cs
- RegionInfo.cs
- RegexWriter.cs
- ObjectStateManager.cs
- SmiXetterAccessMap.cs
- TreeNodeBindingCollection.cs
- DataListItem.cs
- InputProcessorProfilesLoader.cs
- JulianCalendar.cs
- mongolianshape.cs
- StagingAreaInputItem.cs
- ProfilePropertyNameValidator.cs
- PerfService.cs
- SqlConnection.cs
- DocumentPageHost.cs
- SpellerError.cs
- PermissionRequestEvidence.cs
- QueryAsyncResult.cs
- _PooledStream.cs
- ScopeElement.cs
- XmlSchemaSequence.cs
- ChangeBlockUndoRecord.cs
- XmlSchema.cs
- ColorConverter.cs
- Resources.Designer.cs