🚀 Nuova versione beta disponibile! Feedback o problemi? Contattaci

Cookie in PHP

Codegrind TeamJul 22 2023

I cookie sono piccoli frammenti di dati che un server web invia al browser web di un utente e vengono quindi memorizzati sul computer dell’utente. I cookie sono comunemente utilizzati nello sviluppo web per memorizzare temporaneamente informazioni sul dispositivo dell’utente. In PHP, è possibile lavorare con i cookie per migliorare la funzionalità delle tue applicazioni web. In questo articolo, esploreremo cosa sono i cookie, perché dovresti utilizzarli e come creare, leggere, modificare, eliminare e impostare la data di scadenza dei cookie in PHP.

I cookie sono essenzialmente piccoli file di testo che vengono memorizzati sul computer dell’utente quando visitano un sito web. Questi file contengono informazioni che possono essere recuperate dal server web quando l’utente ritorna sullo stesso sito web in futuro. I cookie servono a scopi vari, come la gestione delle sessioni degli utenti, la memorizzazione delle preferenze degli utenti e il tracciamento del comportamento degli utenti.

I cookie vengono utilizzati per diverse ragioni nello sviluppo web:

  1. Gestione delle Sessioni: I cookie possono essere utilizzati per gestire le sessioni degli utenti, consentendo agli utenti di rimanere autenticati mentre navigano in un sito web.

  2. Personalizzazione: I cookie consentono ai siti web di ricordare le preferenze degli utenti, come le impostazioni della lingua o le scelte del tema.

  3. Carrelli della Spesa: Nelle applicazioni di e-commerce, i cookie vengono spesso utilizzati per memorizzare gli articoli nel carrello della spesa tra le visite.

  4. Tracciamento: I cookie possono tracciare il comportamento degli utenti e fornire informazioni preziose per l’analisi del sito web.

Per creare un cookie in PHP, è possibile utilizzare la funzione setcookie. Ecco un esempio di come creare un cookie:

// Sintassi: setcookie(nome, valore, scadenza, percorso, dominio, sicuro, httponly);

$nome = "utente";
$valore = "Giovanni";
$scadenza = time() + 3600; // Il cookie scade in 1 ora
$percorso = "/";
$dominio = "";
$sicuro = false;
$httponly = false;

setcookie($nome, $valore, $scadenza, $percorso, $dominio, $sicuro, $httponly);

Quando crei un cookie in PHP utilizzando la funzione setcookie, puoi specificare vari parametri per personalizzarne il comportamento. Di seguito, spiegheremo in dettaglio ciascun parametro e come influiscono sul comportamento dei cookie.

1. Nome (nome)

Il parametro nome rappresenta il nome del cookie che stai creando. È una stringa che identifica univocamente il cookie all’interno del browser dell’utente. Assicurati di utilizzare nomi univoci per i tuoi cookie.

2. Valore (valore)

Il parametro valore è il contenuto del cookie che desideri memorizzare. Può essere qualsiasi dato serializzabile in formato stringa, come una stringa di testo, un numero o un dato complesso convertito in stringa.

3. Scadenza (scadenza)

Il parametro scadenza determina la data e l’ora in cui il cookie scadrà. È specificato in formato timestamp Unix, che rappresenta il numero di secondi trascorsi dal 1° gennaio 1970 (UTC). Quando il cookie raggiunge la data di scadenza, il browser lo elimina automaticamente.

4. Percorso (percorso)

Il parametro percorso specifica il percorso all’interno del dominio in cui il cookie sarà valido. Se desideri che il cookie sia valido per tutto il tuo dominio, puoi impostare questo parametro su “/” (barra singola).

5. Dominio (dominio)

Il parametro dominio definisce il dominio al quale il cookie è associato. Se non specificato, il cookie è valido solo per il dominio corrente. Puoi impostare questo parametro per consentire al cookie di essere condiviso tra sottodomini o domini diversi.

6. Sicuro (sicuro)

Il parametro sicuro è un valore booleano. Se impostato su true, il cookie verrà trasmesso solo attraverso una connessione HTTPS sicura. Questo aumenta la sicurezza dei dati del cookie durante la trasmissione.

7. Httponly (httponly)

Il parametro httponly è anch’esso un valore booleano. Se impostato su true, il cookie sarà accessibile solo tramite protocollo HTTP e non sarà accessibile tramite JavaScript. Questa impostazione contribuisce a proteggere il cookie da attacchi basati su script.

Per leggere un cookie in PHP, è possibile utilizzare l’array superglobale $_COOKIE. Ecco un esempio:

if(isset($_COOKIE["utente"])) {
    $nomeUtente = $_COOKIE["utente"];
    echo "Benvenuto, $nomeUtente!";
} else {
    echo "Benvenuto sul nostro sito web!";
}

Per modificare il valore di un cookie, è possibile crearne uno nuovo con lo stesso nome e aggiornare il suo valore. Ad esempio:

if(isset($_COOKIE["utente"])) {
    $nuovoNomeUtente = "Giovanna";
    setcookie("utente", $nuovoNomeUtente, time() + 3600, "/");
    echo "Nome utente aggiornato a $nuovoNomeUtente!";
}

Per eliminare un cookie, è possibile impostare la sua data di scadenza a un momento nel passato. Ad esempio, per eliminare il cookie “utente”:

setcookie("utente", "", time() - 3600, "/");

Conclusioni

I cookie sono uno strumento prezioso nello sviluppo web per memorizzare e gestire dati specifici degli utenti. Comprendendo come creare, leggere, modificare, eliminare e impostare la data di scadenza dei cookie in PHP, è possibile migliorare la funzionalità delle tue applicazioni web e offrire un’esperienza più personalizzata agli utenti.