Categoria Dicas CGI/Perl - HTTP Cookies

Posted by webmaster | CGI/Perl |

Há duas maneiras:

1 - Com o módulo CGI:

#!/usr/bin/perl

use CGI; #chamo o módulo CGI
use CGI::Cookie; #dentro dele, chamo o módulo do cookie

$cgi = new CGI;

if ($cgi->cookie(’meu_cookie’)) { #caso o cookie exista, imprimo

print “Content-type: text/html\n\n”; #tipo de documento: HTML
print “Cookie ativo!
“;
print $cgi-cookie(’meu_cookie’); #meu cookie

} else { #se não existe, ele grava

$cookie = $cgi->cookie( -name=>’meu_cookie’, -value=>”Estou gravado!”, -expires=>”+2m”); #gravando o cookie chamado de ‘meu_cookie’ com o valor de ‘Estou gravado’ e expirando em 2 minutos.
print $cgi->header( -cookie=>$cookie ); #imprimo o cookie no navegador
print “Gravando cookie…. ok, salvo!
Atualize seu navegador”;

} #fecho o else

Opções:

-domain => ‘.codigofonte.net’ - significa que o cookie só funcionará com o domínio codigofonte.net.

-path => ‘/cgi-bin/scripts’ - aqui, você colocará o path para o script que irá utilizar este cookie, neste caso, apenas scripts que estão no dir /cgi-bin/scripts poderão utilizar.

-secure => ‘1′ - 1 retorna valor verdadeiro para o navegador, e assim, o cookie só será carregado caso um protocolo criptografado esteja em uso.

2 - Sem utilizar módulo.

Uma outra maneira, não muito recomendada, é a não utilização de módulos.

#!/usr/bin/perl

foreach (split(/; /,$ENV{’HTTP_COOKIE’})) {
$_ =~ s/%([a-fA-F0-9][a-fA-F0-9])/pack(”C”, hex($1))/eg;
($nome,$valor) = split(/=/); $COOKIE{$nome} = $valor;
}

if ($COOKIE{’meu_biscoito’}) { #caso o cookie exista, imprimo

print “Content-type: text/html\n\n”; #tipo de documento: HTML
print “Cookie (biscoito) ativo!
“;
print “$COOKIE{’meu_biscoito’}”; #meu cookie

} else { #se não existe, ele grava

print “Set-Cookie: meu_biscoito=ESTOU GRAVADO VIU?!; expires=+2m ;\n”;
print “Content-type: text/html\n\n”; #tipo de documento: HTML
print “Gravando cookie…. ok, salvo!
Atualize seu navegador”;

} #fecho o else

Além das opções padrões ( name, value, expires ), ainda contamos com os seguintes parâmetros:

domain = ‘.codigofonte.net’ - significa que o cookie só funcionará com o domínio codigofonte.net.

path = ‘/cgi-bin/scripts’ - aqui, você colocará o path para o script que irá utilizar este cookie, neste caso, apenas scripts que estão no dir /cgi-bin/scripts poderão utilizar.

secure = ‘1′ - 1 retorna valor verdadeiro para o navegador, e assim, o cookie só será carregado caso um protocolo criptografado esteja em uso.

Não esqueça de separar com vírgulas ou ponto-vírgulas os atributos que você utilizar, exemplo:

1. $cookie = $cgi->cookie( -name=>’meu_cookie’, -value=>”Estou gravado!”, -domain => ‘.codigofonte.net’, -expires=>”+2m”);

2. [cf] print “Set-Cookie: meu_biscoito=ESTOU GRAVADO VIU?!; domain = ‘.codigofonte.net’; expires=+2m ;\n”; </i> <!– code –>

Para o tempo que o cookie irá existir, você poderá especificar utilizando os códigos a seguir:

<I>s - segundo
m - minuto
h - hora
w - semana
M - mês
y - ano
now - agora</I>

Sendo [cf] +1m </i> <!– code –> para o cookie expirar daqui a 1 minuto. Caso queria que o cookie expire agora, utilize o código [cf]now .

Tags:

Nenhum Comentário

Nenhum comentário ainda.

Feed RSS dos comentários deste post TrackBack URI

O formulário de comentários está fechado no momento.