HttpWebClientProtocol.CookieContainer Eigenschap

Definitie

Hiermee haalt u de verzameling cookies op of stelt u deze in.

public:
 property System::Net::CookieContainer ^ CookieContainer { System::Net::CookieContainer ^ get(); void set(System::Net::CookieContainer ^ value); };
public System.Net.CookieContainer CookieContainer { get; set; }
member this.CookieContainer : System.Net.CookieContainer with get, set
Public Property CookieContainer As CookieContainer

Waarde van eigenschap

Een CookieContainer die de cookies voor een Web Services-client vertegenwoordigt.

Voorbeelden

Het volgende codevoorbeeld is een Web Forms-client van een XML-webservice die sessiestatus gebruikt. De client slaat de HTTP-cookie op die de sessie uniek identificeert door deze op te slaan in de sessiestatus van de client.

<%@ Page Language="C#" %>
<%@ Import Namespace="System.IO" %>
<%@ Import Namespace="System.Net" %>

<html>

    <script runat="server">

        void EnterBtn_Click(Object Src, EventArgs E) 
    {
      // Create a new instance of a proxy class for your XML Web service.
      ServerUsage su = new ServerUsage();
          CookieContainer cookieJar;

      // Check to see if the cookies have already been saved for this session.
      if (Session["CookieJar"] == null) 
        cookieJar= new CookieContainer();
          else
       cookieJar = (CookieContainer) Session["CookieJar"];

        // Assign the CookieContainer to the proxy class.
        su.CookieContainer = cookieJar;

      // Invoke an XML Web service method that uses session state and thus cookies.
      int count = su.PerSessionServiceUsage();         

      // Store the cookies received in the session state for future retrieval by this session.
      Session["CookieJar"] = cookieJar;

          // Populate the text box with the results from the call to the XML Web service method.
          SessionCount.Text = count.ToString();  
        }
         
    </script>
    <body>
       <form runat=server ID="Form1">
           
             Click to bump up the Session Counter.
             <p>
             <asp:button text="Bump Up Counter" Onclick="EnterBtn_Click" runat=server ID="Button1" NAME="Button1"/>
             <p>
             <asp:label id="SessionCount"  runat=server/>
          
       </form>
    </body>
</html>
<%@ Page Language="VB" %>
<%@ Import Namespace="System.IO" %>
<%@ Import Namespace="System.Net" %>

<html>

    <script runat=server>

        Public Sub EnterBtn_Click(src As Object, E As EventArgs) 

      ' Create a new instance of a proxy class for your XML Web service.
      Dim su As ServerUsage = new ServerUsage()
          Dim cookieJar As CookieContainer

      ' Check to see if the cookies have already been saved for this session.
      If (Session("CookieJar") Is Nothing) 
        cookieJar= new CookieContainer()
          Else
       cookieJar = Session("CookieJar")
      End If
   

        ' Assign the CookieContainer to the proxy class.
        su.CookieContainer = cookieJar

      ' Invoke an XML Web service method that uses session state and thus cookies.
      Dim count As Integer = su.PerSessionServiceUsage()         

      ' Store the cookies received in the session state for future retrieval by this session.
      Session("CookieJar") = cookieJar

          ' Populate the text box with the results from the call to the XML Web service method.
          SessionCount.Text = count.ToString()  
    End Sub
         
    </script>
    <body>
       <form runat=server ID="Form1">
           
             Click to bump up the Session Counter.
             <p>
             <asp:button text="Bump Up Counter" Onclick="EnterBtn_Click" runat=server ID="Button1" NAME="Button1"/>
             <p>
             <asp:label id="SessionCount"  runat=server/>
          
       </form>
    </body>
</html>

Opmerkingen

Als een XML-webservicemethode sessiestatus gebruikt, wordt een cookie teruggegeven in de antwoordheaders aan de XML-webserviceclient die de sessie voor die XML-webserviceclient uniek identificeert. Om een XML-webservice de sessiestatus voor een client te behouden, moet de client de cookie opslaan. Clients ontvangen de HTTP-cookie door een nieuw exemplaar te maken van CookieContainer en deze toe te wijzen aan de CookieContainer eigenschap van de proxyklasse voordat de XML-webservicemethode wordt aangeroepen. Als u de sessiestatus buiten het bereik van het proxyklasse-exemplaar wilt houden, moet de client de HTTP-cookie opslaan tussen aanroepen naar de XML-webservice. Een Web Forms-client kan bijvoorbeeld de HTTP-cookie opslaan door de CookieContainer cookie op te slaan in een eigen sessiestatus. Omdat niet alle XML-webservices sessiestatus gebruiken en clients dus niet altijd de eigenschap van een clientproxy moeten gebruiken CookieContainer , moet de documentatie voor de XML-webservice aangeven of de sessiestatus wordt gebruikt.

Van toepassing op

Zie ook