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. |