HttpWebClientProtocol.CookieContainer Propriedade
Definição
Importante
Algumas informações se referem a produtos de pré-lançamento que podem ser substancialmente modificados antes do lançamento. A Microsoft não oferece garantias, expressas ou implícitas, das informações aqui fornecidas.
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
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.