Session.
composer require rancoud/session
By default session is in read only (option read_and_close = 1).
You can specify it using Session::setReadWrite()
or Session::setReadOnly()
Session::start() is not needed, but:
- Session will automatically start in read only when using
get, has, hasKeyAndValue, getAll
- Session will automatically start in write mode when using
set, remove, getAndRemove, keepFlash, gc, regenerate
Set and get value from $_SESSION
Session::set('key', 'value');
$value = Session::get('key');
Use custom options
// first way
Session::setOption('name', 'custom_session_name');
// second way
Session::start(['cookie_lifetime' => 1440]);
Session::set('key', 'value');
$value = Session::get('key');
With encryption on default php session
Session::useDefaultEncryptionDriver('keyForEncryption');
Session::set('key', 'value');
$value = Session::get('key');
With File driver
Session::useFileDriver();
Session::set('key', 'value');
$value = Session::get('key');
With Database driver (you have to install rancoud/database)
$conf = new \Rancoud\Database\Configurator([
'engine' => 'mysql',
'host' => '127.0.0.1',
'user' => 'root',
'password' => '',
'database' => 'test_database'
]);
$db = new \Rancoud\Database\Database($conf);
// for using a current connection
Session::useCurrentDatabaseDriver($db);
// for creating a new connection
//Session::useNewDatabaseDriver($conf);
Session::set('key', 'value');
$value = Session::get('key');
With Redis driver (you have to install predis/predis)
$params = [
'scheme' => 'tcp',
'host' => '127.0.0.1',
'port' => 6379,
];
$redis = new Predis\Client($params);
// for using a current connection
Session::useCurrentRedisDriver($redis);
// for creating a new connection
//Session::useNewRedisDriver($params);
Session::set('key', 'value');
$value = Session::get('key');
With your own driver implementing SessionHandlerInterface
and/or SessionUpdateTimestampHandlerInterface
$driver = new MyCustomDriver();
Session::useCustomDriver($driver);
Session::set('key', 'value');
$value = Session::get('key');
- start([options: array = []]): void
- regenerate(): bool
- destroy(): bool
- commit(): void
- rollback(): bool
- unsaved(): bool
- hasStarted(): bool
- getId(): string
- setId(id: string): string
- gc(): void
- setReadOnly(): void
- setReadWrite(): void
- isReadOnly(): bool
- set(key: string, value: mixed): void
- get(key: string): mixed
- getAll(): array
- getAndRemove(key: string): mixed
- has(key: string): bool
- hasKeyAndValue(key: string, value: mixed): bool
- remove(key: string): void
Flash data are store in a separate variable.
They will dissapear at the end of the script execution or after commit()
unsaved()
.
You can use keepFlash for saving it in $_SESSION.
When flash data is restore, it will be delete in $_SESSION.
- setFlash(key: string, value: mixed): void
- getFlash(key: string): mixed
- getAllFlash(): array
- hasFlash(key: string): bool
- hasFlashKeyAndValue(key: string, value: mixed): bool
- keepFlash([keys: array = []]): void
- setOption(key: string, value): void
- setOptions(options: array): void
- getOption(key: string): mixed
- getDriver(): \SessionHandlerInterface
- useDefaultDriver(): void
- useDefaultEncryptionDriver(key: string, [method: string|null = null]): void
- setLengthSessionID(length: int): void
- getLengthSessionID(): int
- useFileDriver(): void
- useFileEncryptionDriver(key: string, [method: string|null = null]): void
- setPrefixForFile(prefix: string): void
- setLengthSessionID(length: int): void
- getLengthSessionID(): int
- useNewDatabaseDriver(configuration: \Rancoud\Database\Configurator|array): void
- useCurrentDatabaseDriver(databaseInstance: \Rancoud\Database\Database): void
- useNewDatabaseEncryptionDriver(configuration: \Rancoud\Database\Configurator|array, key: string, [method: string = null]): void
- useCurrentDatabaseEncryptionDriver(databaseInstance: \Rancoud\Database\Database, key: string, [method: string = null]): void
- setUserIdForDatabase(userId: int): void
- setLengthSessionID(length: int): void
- getLengthSessionID(): int
- useNewRedisDriver(configuration: array|string): void
- useCurrentRedisDriver(redisInstance: \Predis\Client): void
- useNewRedisEncryptionDriver(configuration: array|string, key: string, [method: string = null]): void
- useCurrentRedisEncryptionDriver(redisInstance: \Predis\Client, key: string, [method: string = null]): void
- setLengthSessionID(length: int): void
- getLengthSessionID(): int
- useCustomDriver(customDriver: \SessionHandlerInterface): void
List of session options you can change:
- save_path
- name
- save_handler
- auto_start
- gc_probability
- gc_divisor
- gc_maxlifetime
- serialize_handler
- cookie_lifetime
- cookie_path
- cookie_domain
- cookie_secure
- cookie_httponly
- cookie_samesite
- use_strict_mode
- use_cookies
- use_only_cookies
- referer_check
- cache_limiter
- cache_expire
- use_trans_sid
- trans_sid_tags
- trans_sid_hosts
- sid_length
- sid_bits_per_character
- upload_progress.enabled
- upload_progress.cleanup
- upload_progress.prefix
- upload_progress.name
- upload_progress.freq
- upload_progress.min_freq
- lazy_write
- read_and_close
Use SessionHandler
Extends SessionHandler
You need to install
composer require rancoud/database
CREATE TABLE IF NOT EXISTS `sessions` (
`id` varchar(128) NOT NULL,
`id_user` int(10) unsigned DEFAULT NULL,
`last_access` datetime NOT NULL,
`content` text NOT NULL,
PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8;
You need to install
composer require predis/predis
docker compose build && docker compose run lib composer ci
for launching tests