Code:
/ Dotnetfx_Vista_SP2 / Dotnetfx_Vista_SP2 / 8.0.50727.4016 / DEVDIV / depot / DevDiv / releases / whidbey / NetFxQFE / 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
- MenuEventArgs.cs
- StylusShape.cs
- UpdatableWrapper.cs
- StrokeCollection2.cs
- Paragraph.cs
- CommentEmitter.cs
- CompModSwitches.cs
- ViewSimplifier.cs
- EntityModelSchemaGenerator.cs
- Parser.cs
- PositiveTimeSpanValidatorAttribute.cs
- ToolStripComboBox.cs
- _Events.cs
- DataBindingExpressionBuilder.cs
- FieldAccessException.cs
- OracleFactory.cs
- AnimatedTypeHelpers.cs
- ViewValidator.cs
- SrgsGrammarCompiler.cs
- DSASignatureFormatter.cs
- DefaultHttpHandler.cs
- SerializableAttribute.cs
- MeshGeometry3D.cs
- HandlerWithFactory.cs
- GraphicsPath.cs
- DataControlFieldCell.cs
- CodeAttributeDeclaration.cs
- ApplicationInterop.cs
- RolePrincipal.cs
- AuthorizationRuleCollection.cs
- NativeMethods.cs
- Panel.cs
- DetailsViewDeleteEventArgs.cs
- HttpDigestClientCredential.cs
- CustomError.cs
- DataGridViewCellStyle.cs
- Trace.cs
- CompositeFontInfo.cs
- HtmlButton.cs
- ParameterCollection.cs
- Interop.cs
- RealProxy.cs
- MatrixStack.cs
- SqlProviderManifest.cs
- ConnectionStringSettingsCollection.cs
- Odbc32.cs
- SimpleMailWebEventProvider.cs
- SecurityResources.cs
- input.cs
- XmlSchemaImporter.cs
- DecimalAnimationBase.cs
- CodeDOMUtility.cs
- DataServiceHostFactory.cs
- DateTimeValueSerializerContext.cs
- SizeF.cs
- DataGridBoolColumn.cs
- ExpandCollapseProviderWrapper.cs
- ContentPresenter.cs
- ReflectPropertyDescriptor.cs
- WebRequestModulesSection.cs
- DataGrid.cs
- AsyncOperationContext.cs
- QueryResponse.cs
- FormViewPagerRow.cs
- SmtpFailedRecipientException.cs
- FormsAuthenticationTicket.cs
- XmlValidatingReaderImpl.cs
- HttpDictionary.cs
- InteropAutomationProvider.cs
- TableRow.cs
- BindingCollection.cs
- GridViewRow.cs
- ItemCollection.cs
- ImportRequest.cs
- ChangeProcessor.cs
- CodeGeneratorAttribute.cs
- XmlSerializerAssemblyAttribute.cs
- ByteStream.cs
- QuadraticBezierSegment.cs
- XPathArrayIterator.cs
- WSHttpSecurityElement.cs
- ColorConverter.cs
- BinaryConverter.cs
- FixedSOMImage.cs
- DoubleCollection.cs
- WsatTransactionInfo.cs
- CachedTypeface.cs
- DataServiceOperationContext.cs
- ForAllOperator.cs
- Wildcard.cs
- LinearGradientBrush.cs
- ChildrenQuery.cs
- TextLineBreak.cs
- SessionPageStatePersister.cs
- ObjectReaderCompiler.cs
- XXXInfos.cs
- ValidationEventArgs.cs
- DbConnectionStringCommon.cs
- VirtualizingPanel.cs
- WebZone.cs