Um cookie é um pequeno pedaço de dados enviado de a partir de um website e armazenado em um arquivo de texto criado no computador do usuário enquanto ele está navegando em um site. Cada vez que o usuário carrega o website, o navegador envia o cookie de volta ao servidor para notificar o site da atividade prévia do usuário. Os cookies foram projetados para serem um mecanismo confiável para sites recordarem informações de estado ou para registrar a atividade de navegação do usuário.
Cookie é um assunto que trouxe e ainda levanta muita controvérsia no universo da computação para web, devido a questões de segurança quanto a manipular informações no computador local, fazem com que todos os tipos de usuários se preocupe com as informações utilizadas em websites principalmente se utilizar computadores que são compartilhados com varias pessoas como em lan houses ou outros.
C# possui a classe HttpCookie que permite que o desenvolvedor manipule cookies em suas aplicações web seguindo as especificações do RFC 2109, está classe representa os valores de um cookie HTTP.
Cookies: https://www.ietf.org/rfc/rfc2109.txt
HttpCookie: System.Web
Utilizando Cookies
1- Crie uma aplicação do tipo ASP.NET Web Application com o modelo C# Empty e chame seu projeto de DACookie, crie uma nova pagina WebForm chamada default. Copie o código para a pagina e rode o programa:
2 – Assim que o botão recebe o evento de clique o método Post cria o cookie no computador local guardando em seu arquivo o nome do usuário, a pagina é recarregada e o cookie é lido automaticamente, toda vez que você tentar recarregar esta página o cookie será lido e o nome guardado automaticamente preenchido:
Para ver o cookie e no seu navegador (Firefox) abra Opções no menu do Firefox e escolha a aba privacidade:
4 – Clique no link excluir cookies em particular e digite no campo de busca, localhost. Selecione o cookie pelo seu nome e você pode ver os dados gravados no mesmo. Caso queira testar o exemplo outra vez você pode excluir o cookie e rodar a aplicação novamente:
Exemplo:
Neste exemplo criamos uma página que grava e lê um cookie no computador local.
C#
Default.aspx
<%@ Page Language="C#" AutoEventWireup="true" CodeBehind="default.aspx.cs" Inherits="DACookies._default" %> <!DOCTYPE html> <html xmlns="http://www.w3.org/1999/xhtml"> <head runat="server"> <title></title> </head> <body> <h1>Desenvolvimento Aberto</h1> <h2>Cookies Memoriza Dados</h2> <form id="form1" runat="server"> <div> <asp:Label ID="Label1" runat="server" Text="Nome: "></asp:Label> <asp:TextBox ID="TextBox1" runat="server" Width="292px"></asp:TextBox> <asp:Button ID="Button1" runat="server" OnClick="Button1_Click" Text="Adicionar" /> </div> </form> </body> </html>
Default.aspx.cs
using System; using System.Collections.Generic; using System.Linq; using System.Web; using System.Web.UI; using System.Web.UI.WebControls; namespace DACookies { public partial class _default : System.Web.UI.Page { protected void Page_Load(object sender, EventArgs e) { // Recupera Cookie HttpCookie cookie = Request.Cookies.Get("DAMeuCookie"); // Verifica se existe Cookie if (cookie != null) { // Modifica pagina Label1.Text = cookie.Value; TextBox1.Visible = false; Button1.Visible = false; } } protected void Button1_Click(object sender, EventArgs e) { // Recupera parametro string nome = Request.Form["TextBox1"]; // Cria objeto Cookie HttpCookie cookie = new HttpCookie("DAMeuCookie"); cookie.Value = nome; // Adiciona cookie a coleção Response.Cookies.Add(cookie); // Redireciona pagina Response.Redirect("default.aspx"); } } }