Documentation

Sessions

Présentation

Le système de session permet de stocker temporairement des variables, qui sont liées à un visiteur. L'intérêt est de faire des traitements dans un contrôleur en fonction des traitements effectuée précédemment dans les contrôleurs exécutés préalablement.
Chaque session est liée à un navigateur par le biais d'un cookie déposé au premier accès. Cela est transparent car géré par le framework.

L'objet de gestion des sessions est créé automatiquement par Temma, si la configuration le prévoit.

Dans les contrôleurs, l'objet de session est disponible en écrivant :

$this->_session

Dans les autres objets gérés par le composant d'injection de dépendances, l'objet de session est accessible en écrivant :

$this->_loader->session

Lecture de données

Pour lire des données depuis la session, il suffit d'utiliser l'objet comme un tableau associatif :

$currentUser = $this->_session['user'];

Pour savoir si une variable de session existe, ou si elle est vide :

// est-ce que la variable est définie ?
if (isset($this->_session['myVariable']))
    doSomething();

// est-ce que la variable est vide ?
if (empty($this->_session['myOtherVariable']))
    doSomethingElse();

// variable non définie : utilisation d'une valeur par défaut
$var = $this->_session['myVariable'] ?? 'defaultValue';

// variable non définie ou vide : valeur par défaut
$var = $this->_session['myVariable'] ?: 'defaultValue';

Il est possible de récupérer toutes les variables de session avec la méthode getAll() :

$sessVariables = $this->_session->getAll();
$currentUser = $sessVariables['user'];
$basket = $sessVariables['basket'];

Écriture de données

Pour créer ou modifier une variable de session :

$this->_session['myVariable'] = $value;

Si la valeur assignée à la variable vaut null, la variable est effacée de la session.

Pour lire et écrire des données, l'objet de gestion des sessions s'utilise comme un tableau. Mais cela ne permet pas d'écrire directement des valeurs sur des tableaux multi-dimensionnels.
Pour modifier un tableau multi-dimensionnel, il faut donc commencer par récupérer le tableau complet, le modifier, puis écraser la variable de session :

// cela ne fonctionne pas
$this->_session['user']['name'] = 'Einstein';

// il faut procéder ainsi
$user = $this->_session['user'];
$user['name'] = 'Einstein';
$this->_session['user'] = $user;

Effacement de données

Pour détruire une variable de session :

unset($this->_session['myVariable']);

Pour effacer toutes les variables de la session :

$this->_session->clean();
Précédent : Injection de dépendances
Suivant : Cache

Table des matières