Partilhar via


HttpWebClientProtocol.CookieContainer Propriedade

Definição

Obtém ou define a coleção de cookies.

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

Valor da propriedade

CookieContainer

Um CookieContainer que representa os cookies para um cliente de serviços Web.

Exemplos

O exemplo de código a seguir é um cliente Web Forms de um serviço Web XML que usa o estado da sessão. O cliente armazena o cookie HTTP que identifica exclusivamente a sessão armazenando-a no estado de sessão do cliente.

<%@ 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>

Comentários

Se um método de serviço Web XML usar o estado da sessão, um cookie será passado de volta nos cabeçalhos de resposta para o cliente de serviço Web XML que identifica exclusivamente a sessão para esse cliente de serviço Web XML. Para que um serviço Web XML mantenha o estado da sessão para um cliente, o cliente deve armazenar o cookie. Os clientes recebem o cookie HTTP criando uma nova instância CookieContainer e atribuindo-a CookieContainer à propriedade da classe proxy antes de chamar o método de serviço Web XML. Se você precisar manter o estado de sessão além de quando a instância da classe proxy ficar fora do escopo, o cliente deverá armazenar o cookie HTTP entre chamadas para o serviço Web XML. Por exemplo, um cliente Web Forms pode armazenar o cookie HTTP salvando-o CookieContainer em seu próprio estado de sessão. Como nem todos os serviços Web XML usam o estado da sessão e, portanto, os clientes nem sempre são necessários para usar a CookieContainer propriedade de um proxy de cliente, a documentação do serviço Web XML deve declarar se o estado da sessão é usado.

Aplica-se a

Confira também