PHPerKaigi 2025

session_encode

(PHP 4, PHP 5, PHP 7, PHP 8)

session_encode Kodiert die Daten der aktuellen Session als session-kodierte Zeichenkette

Beschreibung

session_encode(): string|false

session_encode() gibt eine serialisierte Zeichenkette des Inhalts der aktuellen Session, der in der $_SESSION-Superglobalen gespeichert ist, zurück.

Standardmäßig ist das verwendete Serialisierungsverfahren PHP-intern, und nicht dasselbe wie bei serialize(). Das Serialisierungsverfahren kann mit der Konfigurationsoption session.serialize_handler festgelegt werden.

Parameter-Liste

Diese Funktion besitzt keine Parameter.

Rückgabewerte

Gibt Inhalt der aktuellen Session kodiert zurück. Bei einem Fehler wird false zurückgegeben.

Anmerkungen

Warnung

session_start() muss vor session_encode() aufgerufen werden.

Siehe auch

add a note

User Contributed Notes 3 notes

up
19
<carlos sica>sica at wnet dot com dot br
19 years ago
session_encode() just return the session dataset in a formatted form

session_start();

$_SESSION['login_ok'] = true;
$_SESSION['nome'] = 'sica';
$_SESSION['inteiro'] = 34;

echo session_encode();

this code will print

login_ok|b:1;nome|s:4:"sica";inteiro|i:34;
up
2
Mark P
7 years ago
session_encode() can't handle pipes in your keys.

<?php
session_start
();
$_SESSION = ['foo|bar'=>'ba;z']; pathetic
dump
(session_encode()); // false because "foo|bar" contains a pipe
?>
up
0
polygon dot co dot in at gmail dot com
1 month ago
The session_encode and session_decode functions are incomplete.

Because there is no option to collect the output values for session_decode or input an array in session_encode.

I faced this issue while trying to implement custom session using session_set_save_handler.

It led me to limit the functionality to particular serialize_handler and had to hardcode the encode and decode functions like serialize and unserialize for option ['serialize_handler' => 'php_serialize'] instead of session_encode and session_decode once i am done with defining the encoding algo.
To Top