popphp / pop-session
Pop Session Component for Pop PHP Framework
Installs: 6 341
Dependents: 4
Suggesters: 0
Security: 0
Stars: 3
Watchers: 3
Forks: 1
Open Issues: 0
Requires
- php: >=8.1.0
Requires (Dev)
- phpunit/phpunit: ^10.0.0
This package is auto-updated.
Last update: 2024-11-19 05:19:47 UTC
README
Overview
pop-session
is a component used to manage sessions and session data in the PHP web environment.
It includes the ability to also manage namespaces within the session as well as timed-based and
request-based expirations.
pop-session
is a component of the Pop PHP Framework.
Install
Install pop-session
using Composer.
composer require popphp/pop-session
Or, require it in your composer.json file
"require": {
"popphp/pop-session" : "^4.0.0"
}
Quickstart
You can create a session and store and fetch data from it:
use Pop\Session\Session; $sess = Session::getInstance(); // Set session values $sess->foo = 'bar'; $sess['baz'] = 123; // Access session values echo $sess['foo']; echo $sess->baz;
You can unset session data like this:
unset($sess->foo); unset($sess['baz']);
And finally, you can destroy the whole session like this:
$sess->kill();
Time-Based
Session values can be made available based on time expiration:
use Pop\Session\Session; $sess = Session::getInstance(); $sess->setTimedValue('foo', 'bar', 10); // # of seconds
Then, the next request will be successful if it's within the time limit of that session data:
use Pop\Session\Session; if (isset($sess->foo)) { echo $sess->foo; } else { echo 'Nope!'; }
Request-Based
Session values can be made available based on number of requests:
use Pop\Session\Session; $sess = Session::getInstance(); $sess->setRequestValue('foo', 'bar', 1); // # of requests
Then, the next request will be successful if it's within the set limit of number requests allowed before that session data is expired:
if (isset($sess->foo)) { echo $sess->foo; } else { echo 'Nope!'; }
Namespaces
You can store session data under a namespace to separate that data from the global session data:
use Pop\Session\SessionNamespace; $sessMyApp = new SessionNamespace('MyApp'); $sessMyApp->foo = 'bar' if (isset($sessMyApp->foo)) { echo $sessMyApp->foo; // Only available under the namespace. } else { echo 'Nope!'; }
Session namespaces can also store time-based and request-based session data:
use Pop\Session\SessionNamespace; $sessMyApp = new SessionNamespace('MyApp'); $sessMyApp->setTimedValue('foo', 'bar', 10); // # of seconds $sessMyApp->setRequestValue('foo', 'bar', 1); // # of requests