maer/session

A dead simple and basic session library

1.0.0 2015-11-17 23:32 UTC

This package is auto-updated.

Last update: 2025-01-09 01:58:00 UTC


README

Build Status

Manage PHP sessions and flash sessions in a simple way.

Install

Clone this repository or use composer to download the library with the following command:

composer require maer/session 1.*

Set up

Load the library via composers autoloader:

include '/path/to/vendor/autoload.php';

Load the library manually:

include '/path/to/library/src/SessionInterface.php';
include '/path/to/library/src/Session.php';

Example

When a session instance is created, it will check if the session already is started. If not, it will start it using session_start().

Managing sessions

$session = new Maer\Session\Session();

// Set a value
$session->set('my-key', 'my-value');

// Get a value
$value = $session->get('my-key');

// Add an optional second argument
$value = $session->get('non-existint-key', 'this-will-be-returned');

// Check if a key exists
if ($session->has('my-key')) {
    // Yay... it exists!
} else {
   // Darn! It didn't exist!
}

// Forget/clear/remove a session key
$session->forget('my-key');

// Forget/clear/remove all session keys and destroy the session cookie
$session->destroy();

Flash sessions

A flash session is a "one-request-only"-session. If you set a flash session, it is only accessable in the next request and will then be removed. It's perfect for things like success/status/error messages.

// Set a flash session
$session->setFlash('error', 'This is an error message');

// On the next request
$value = $session->getFlash('error');

// Add an optional second argument
$value = $session->get('non-existint-key', 'this-will-be-returned');

Both ->get(...) and ->getFlash(...) returns NULL as default if the key isn't found.

I told you it was dead simple!

If you have any questions, suggestions or issues, let me know!

Happy coding!