Exemplu
Următorul exemplu creează un cookie numit "user" cu valoarea "John Doe" . Cookie - ul va expira după 30 de zile (86400 * 30) . "/" Înseamnă că cookie - ul este disponibil în întregul site (otherwise, select the directory you prefer) în (otherwise, select the directory you prefer) care o (otherwise, select the directory you prefer) .
Apoi am prelua valoarea cookie -ului "user" (folosind $ _COOKIE variabila la nivel mondial). Noi folosim , de asemenea, isset() funcția pentru a afla dacă cookie - ul este setat:
<!DOCTYPE html>
<?php
$cookie_name = "user";
$cookie_value = "John
Doe";
setcookie($cookie_name, $cookie_value, time() + (86400 * 30), "/");
// 86400 = 1 day
?>
<html>
<body>
<?php
if(!isset($_COOKIE[$cookie_name]))
{
echo "Cookie named '" . $cookie_name . "' is not
set!";
} else {
echo "Cookie '" . $cookie_name
. "' is set!<br>";
echo "Value is: " . $_COOKIE[$cookie_name];
}
?>
</body>
</html>
Run exemplu » Definiție și utilizare
setcookie() funcția definește un cookie pentru a fi trimis împreună cu restul antetele HTTP.
Un cookie este adesea folosit pentru a identifica un utilizator. Un cookie este un mic fișier pe care serverul embeds pe calculatorul utilizatorului. De fiecare dată același computer solicită o pagină cu un browser, acesta va trimite cookie-ul prea. Cu PHP, puteți crea atât și de a prelua valorile cookie-uri.
Numele cookie-ul este atribuit în mod automat la o variabilă cu același nume. De exemplu, în cazul în care un cookie a fost trimis cu numele de "user" , o variabilă este automat creat numit utilizator $, care conține valoarea cookie.
Note: setcookie() funcția trebuie să apară înainte de <html> tag - ul.
Note: Valoarea cookie - ul este urlencoded automat la trimiterea cookie, și decodificate în mod automat atunci când a primit (pentru a preveni URLencoding, utilizarea setrawcookie() în loc).
Sintaxă
setcookie( name,value,expire,path,domain,secure,httponly );
Parametru | Descriere |
---|---|
name | Necesar. Specifică numele cookie- |
value | Opțional. Specifică valoarea cookie-ului |
expire | Opțional. Specifică când expiră cookie. Valoarea: time() + 86400 * 30, va seta cookie să expire în 30 de zile. Dacă acest parametru este omis sau setat la 0, cookie - ul va expira la sfârșitul sesiunii (when the browser closes) se (when the browser closes) . Implicit este 0 |
path | Opțional. Specifică calea serverului de cookie. Dacă este setat la "/" , cookie - ul va fi disponibil în întregul domeniu. Dacă este setat la "/php/" , cookie - ul va fi disponibil în directorul php și toate sub-directoarele de php numai. Valoarea implicită este directorul curent care cookie-ul este setat în |
domain | Opțional. Specifică numele de domeniu cookie. Pentru a face cookie disponibil pentru toate subdomeniile example.com, domeniu setat la "example.com" . Setarea pe www.example.com va face cookie-ul disponibil doar în subdomeniul www |
secure | Opțional. Specifică dacă cookie-ul ar trebui să fie transmise numai printr-o conexiune securizată HTTPS. TRUE indică faptul că cookie-ul va fi setat numai dacă există o conexiune securizată. Implicit este FALSE |
httponly | Opțional. Dacă este setat la TRUE cookie - ul va fi accesibil numai prin protocolul HTTP (the cookie will not be accessible by scripting languages) - (the cookie will not be accessible by scripting languages) de (the cookie will not be accessible by scripting languages) . Această setare poate ajuta la reducerea furtului de identitate prin atacuri XSS. Implicit este FALSE |
Detalii tehnice
Întoarcere Valoare: | TRUE în caz de succes. FALSE în cazul eșecului |
---|---|
Versiune PHP: | 4+ |
PHP Changelog: | PHP 5.5 - un atribut max-age a fost inclusă în antetul Set-Cookie trimis la client PHP 5.2 - a fost adăugat Parametrul HttpOnly |
Mai multe exemple
Exemplu
Mai multe expiră datele pentru cookie-uri:
<?php
$value = "Hello world!";
// cookie will expire when the
browser close
setcookie("myCookie", $value);
// cookie will expire
in 1 hour
setcookie("myCookie", $value, time() + 3600);
// cookie
will expire in 1 hour, and will only be available
// within the php
directory + all sub-directories of php
setcookie("myCookie", $value,
time() + 3600, "/php/");
?>
<html>
<body>
...some code...
</body>
</html>
Run exemplu » Exemplu
Pentru a modifica un cookie, trebuie doar să setați (again) cookie - ul folosind setcookie() funcția de :
<?php
$cookie_name = "user";
$cookie_value = "Alex
Porter";
setcookie($cookie_name, $cookie_value, time() + (86400 * 30), "/");
?>
<html>
<body>
<?php
if(!isset($_COOKIE[$cookie_name]))
{
echo "Cookie named '" . $cookie_name . "' is not
set!";
} else {
echo "Cookie '" . $cookie_name
. "' is set!<br>";
echo "Value is: " . $_COOKIE[$cookie_name];
}
?>
</body>
</html>
Run exemplu » Exemplu
Pentru a șterge un modul cookie, utilizați setcookie() funcția cu o dată de expirare în trecut:
<?php
// set the expiration date to one hour ago
setcookie("user",
"" , time() - 3600);
?>
<html>
<body>
<?php
echo "Cookie 'user'
is deleted.";
?>
</body>
</html>
Run exemplu » Exemplu
Creați un mic script care verifică dacă cookies - cookies sunt activate. În primul rând, încercați să creați un cookie de test cu setcookie() funcția, apoi conta variabila matrice $ _COOKIE:
<?php
setcookie("test_cookie", "test" , time() + 3600, '/');
?>
<html>
<body>
<?php
if(count($_COOKIE) > 0) {
echo "Cookies are enabled.";
} else {
echo "Cookies
are disabled.";
}
?>
</body>
</html>
Run exemplu » <PHP HTTP Reference