Ruby - Sessioni CGI

Una CGI :: Session mantiene uno stato persistente per gli utenti Web in un ambiente CGI. Le sessioni dovrebbero essere chiuse dopo l'uso, in quanto ciò garantisce che i loro dati vengano scritti nel negozio. Quando hai terminato definitivamente una sessione, dovresti eliminarla.

#!/usr/bin/ruby

require 'cgi'
require 'cgi/session'
cgi = CGI.new("html4")

sess = CGI::Session.new( cgi, "session_key" => "a_test", "prefix" => "rubysess.")
lastaccess = sess["lastaccess"].to_s
sess["lastaccess"] = Time.now
if cgi['bgcolor'][0] =~ /[a-z]/
   sess["bgcolor"] = cgi['bgcolor']
end

cgi.out {
   cgi.html {
      cgi.body ("bgcolor" => sess["bgcolor"]) {
         "The background of this page"    +
         "changes based on the 'bgcolor'" +
         "each user has in session."      +
         "Last access time: #{lastaccess}"
      }
   }
}

Accedendo a "/cgi-bin/test.cgi?bgcolor = red" la pagina diventa rossa per un singolo utente per ogni hit successivo fino a quando un nuovo "bgcolor" non viene specificato tramite l'URL.

I dati della sessione vengono memorizzati in un file temporaneo per ogni sessione e il parametro prefix assegna una stringa da anteporre al nome del file, rendendo le sessioni facilmente identificabili sul filesystem del server.

CGI :: Session manca ancora di molte funzionalità, come la capacità di memorizzare oggetti diversi dalle stringhe, l'archiviazione di sessioni su più server.

Classe CGI :: Sessione

Una CGI :: Session mantiene uno stato persistente per gli utenti web in un ambiente CGI. Le sessioni possono essere residenti in memoria o possono essere archiviate su disco.

Metodi di classe

Ruby class Class CGI :: Session fornisce un unico metodo di classe per creare una sessione -

CGI::Session::new( cgi[, option])

Avvia una nuova sessione CGI e restituisce l'oggetto CGI :: Session corrispondente. opzione può essere un hash di opzione che specifica uno o più dei seguenti:

  • session_key- Nome della chiave contenente l'ID della sessione. L'impostazione predefinita è _session_id.

  • session_id- ID sessione univoco. Generato automaticamente

  • new_session- Se true, crea un nuovo ID sessione per questa sessione. Se falso, utilizza una sessione esistente identificata da session_id. Se omesso, utilizza una sessione esistente se disponibile, altrimenti creane una nuova.

  • database_manager- Classe da utilizzare per salvare le sessioni; può essere CGI :: Session :: FileStore o CGI :: Session :: MemoryStore. L'impostazione predefinita è FileStore.

  • tmpdir - Per FileStore, directory per i file di sessione.

  • prefix - Per FileStore, prefisso dei nomi dei file di sessione.

Metodi di istanza

Sr.No. Metodi e descrizione
1

[ ]

Restituisce il valore per la chiave data. Vedi esempio sopra.

2

[ ]=

Imposta il valore per la chiave data. Vedi esempio sopra.

3

delete

Chiama il metodo di eliminazione del gestore database sottostante. Per FileStore, elimina il file fisico contenente la sessione. Per MemoryStore, rimuove la sessione dalla memoria.

4

update

Chiama il metodo di aggiornamento del gestore database sottostante. Per FileStore, scrive i dati della sessione su disco. Non ha effetto con MemoryStore.