3v4l.org

run code in 300+ PHP versions simultaneously
<?php class MySessionStorage implements SessionHandlerInterface { private $path; function open($savePath, $sessionName) { $this->path = $savePath; } function close() { } function read($id) { return ''; } function write($id, $data) { return TRUE; } function destroy($id) { return TRUE; } function gc($maxlifetime) { return TRUE; } } session_set_save_handler(new MySessionStorage); $toto = session_start();
Output for 8.1.0 - 8.1.27, 8.2.0 - 8.2.17, 8.3.0 - 8.3.4
Deprecated: Return type of MySessionStorage::open($savePath, $sessionName) should either be compatible with SessionHandlerInterface::open(string $path, string $name): bool, or the #[\ReturnTypeWillChange] attribute should be used to temporarily suppress the notice in /in/qAsWe on line 8 Deprecated: Return type of MySessionStorage::close() should either be compatible with SessionHandlerInterface::close(): bool, or the #[\ReturnTypeWillChange] attribute should be used to temporarily suppress the notice in /in/qAsWe on line 13 Deprecated: Return type of MySessionStorage::read($id) should either be compatible with SessionHandlerInterface::read(string $id): string|false, or the #[\ReturnTypeWillChange] attribute should be used to temporarily suppress the notice in /in/qAsWe on line 17 Deprecated: Return type of MySessionStorage::write($id, $data) should either be compatible with SessionHandlerInterface::write(string $id, string $data): bool, or the #[\ReturnTypeWillChange] attribute should be used to temporarily suppress the notice in /in/qAsWe on line 22 Deprecated: Return type of MySessionStorage::destroy($id) should either be compatible with SessionHandlerInterface::destroy(string $id): bool, or the #[\ReturnTypeWillChange] attribute should be used to temporarily suppress the notice in /in/qAsWe on line 27 Deprecated: Return type of MySessionStorage::gc($maxlifetime) should either be compatible with SessionHandlerInterface::gc(int $max_lifetime): int|false, or the #[\ReturnTypeWillChange] attribute should be used to temporarily suppress the notice in /in/qAsWe on line 32 Warning: session_set_save_handler(): Session save handler cannot be changed after headers have already been sent in /in/qAsWe on line 39 Warning: session_start(): Session cannot be started after headers have already been sent in /in/qAsWe on line 42
Output for 8.0.0 - 8.0.30
Fatal error: Uncaught TypeError: Session callback must have a return value of type bool, null returned in /in/qAsWe:42 Stack trace: #0 /in/qAsWe(42): session_start() #1 {main} thrown in /in/qAsWe on line 42
Process exited with code 255.
Output for 7.2.0 - 7.2.33, 7.3.0 - 7.3.33, 7.4.0 - 7.4.33
Warning: session_start(): Session callback expects true/false return value in /in/qAsWe on line 42 Warning: session_start(): Session callback expects true/false return value in /in/qAsWe on line 42 Warning: session_start(): Failed to initialize storage module: user (path: ) in /in/qAsWe on line 42
Output for 7.1.0 - 7.1.33
Warning: session_start(): Session callback expects true/false return value in /in/qAsWe on line 42 Warning: session_start(): Session callback expects true/false return value in /in/qAsWe on line 42 Fatal error: session_start(): Failed to initialize storage module: user (path: ) in /in/qAsWe on line 42
Process exited with code 255.
Output for 7.0.0 - 7.0.33
Warning: session_start(): Session callback expects true/false return value in /in/qAsWe on line 42 Fatal error: session_start(): Failed to initialize storage module: user (path: ) in /in/qAsWe on line 42 Warning: Unknown: Session callback expects true/false return value in Unknown on line 0
Process exited with code 255.
Output for 5.5.0 - 5.5.38, 5.6.0 - 5.6.40

preferences:
226.02 ms | 401 KiB | 326 Q