Find this useful? Enter your email to receive occasional updates for securing PHP code.
Signing you up...
Thank you for signing up!
PHP Decode
--TEST-- Test session_decode() function : basic functionality --EXTENSIONS-- session --SKI..
Decoded Output download
--TEST--
Test session_decode() function : basic functionality
--EXTENSIONS--
session
--SKIPIF--
<?php include('skipif.inc'); ?>
--FILE--
<?php
ob_start();
echo "*** Testing session_decode() : basic functionality ***
";
// Get an unset variable
$unset_var = 10;
unset($unset_var);
class classA
{
public function __toString() {
return "Hello World!";
}
}
$heredoc = <<<EOT
Hello World!
EOT;
$fp = fopen(__FILE__, "r");
// Unexpected values to be passed as arguments
$inputs = array(
// Integer data
/*1*/ 0,
1,
12345,
-2345,
// Float data
/*5*/ 10.5,
-10.5,
12.3456789000e10,
12.3456789000E-10,
.5,
// Null data
/*10*/ NULL,
null,
// Boolean data
/*12*/ true,
false,
TRUE,
FALSE,
// Empty strings
/*16*/ "",
'',
// Invalid string data
/*18*/ "Nothing",
'Nothing',
$heredoc,
// Object data
/*21*/ new classA(),
// Undefined data
/*22*/ @$undefined_var,
// Unset data
/*23*/ @$unset_var,
// Resource variable
/*24*/ $fp
);
ini_set('session.serialize_handler', 'php_serialize');
var_dump(session_start());
$iterator = 1;
foreach($inputs as $input) {
echo "
-- Iteration $iterator --
";
$_SESSION["data"] = $input;
$encoded = session_encode();
var_dump(session_decode($encoded));
var_dump($_SESSION);
$iterator++;
};
var_dump(session_destroy());
fclose($fp);
echo "Done";
ob_end_flush();
?>
--EXPECT--
*** Testing session_decode() : basic functionality ***
bool(true)
-- Iteration 1 --
bool(true)
array(1) {
["data"]=>
int(0)
}
-- Iteration 2 --
bool(true)
array(1) {
["data"]=>
int(1)
}
-- Iteration 3 --
bool(true)
array(1) {
["data"]=>
int(12345)
}
-- Iteration 4 --
bool(true)
array(1) {
["data"]=>
int(-2345)
}
-- Iteration 5 --
bool(true)
array(1) {
["data"]=>
float(10.5)
}
-- Iteration 6 --
bool(true)
array(1) {
["data"]=>
float(-10.5)
}
-- Iteration 7 --
bool(true)
array(1) {
["data"]=>
float(123456789000)
}
-- Iteration 8 --
bool(true)
array(1) {
["data"]=>
float(1.23456789E-9)
}
-- Iteration 9 --
bool(true)
array(1) {
["data"]=>
float(0.5)
}
-- Iteration 10 --
bool(true)
array(1) {
["data"]=>
NULL
}
-- Iteration 11 --
bool(true)
array(1) {
["data"]=>
NULL
}
-- Iteration 12 --
bool(true)
array(1) {
["data"]=>
bool(true)
}
-- Iteration 13 --
bool(true)
array(1) {
["data"]=>
bool(false)
}
-- Iteration 14 --
bool(true)
array(1) {
["data"]=>
bool(true)
}
-- Iteration 15 --
bool(true)
array(1) {
["data"]=>
bool(false)
}
-- Iteration 16 --
bool(true)
array(1) {
["data"]=>
string(0) ""
}
-- Iteration 17 --
bool(true)
array(1) {
["data"]=>
string(0) ""
}
-- Iteration 18 --
bool(true)
array(1) {
["data"]=>
string(7) "Nothing"
}
-- Iteration 19 --
bool(true)
array(1) {
["data"]=>
string(7) "Nothing"
}
-- Iteration 20 --
bool(true)
array(1) {
["data"]=>
string(12) "Hello World!"
}
-- Iteration 21 --
bool(true)
array(1) {
["data"]=>
object(classA)#2 (0) {
}
}
-- Iteration 22 --
bool(true)
array(1) {
["data"]=>
NULL
}
-- Iteration 23 --
bool(true)
array(1) {
["data"]=>
NULL
}
-- Iteration 24 --
bool(true)
array(1) {
["data"]=>
int(0)
}
bool(true)
Done
Did this file decode correctly?
Original Code
--TEST--
Test session_decode() function : basic functionality
--EXTENSIONS--
session
--SKIPIF--
<?php include('skipif.inc'); ?>
--FILE--
<?php
ob_start();
echo "*** Testing session_decode() : basic functionality ***\n";
// Get an unset variable
$unset_var = 10;
unset($unset_var);
class classA
{
public function __toString() {
return "Hello World!";
}
}
$heredoc = <<<EOT
Hello World!
EOT;
$fp = fopen(__FILE__, "r");
// Unexpected values to be passed as arguments
$inputs = array(
// Integer data
/*1*/ 0,
1,
12345,
-2345,
// Float data
/*5*/ 10.5,
-10.5,
12.3456789000e10,
12.3456789000E-10,
.5,
// Null data
/*10*/ NULL,
null,
// Boolean data
/*12*/ true,
false,
TRUE,
FALSE,
// Empty strings
/*16*/ "",
'',
// Invalid string data
/*18*/ "Nothing",
'Nothing',
$heredoc,
// Object data
/*21*/ new classA(),
// Undefined data
/*22*/ @$undefined_var,
// Unset data
/*23*/ @$unset_var,
// Resource variable
/*24*/ $fp
);
ini_set('session.serialize_handler', 'php_serialize');
var_dump(session_start());
$iterator = 1;
foreach($inputs as $input) {
echo "\n-- Iteration $iterator --\n";
$_SESSION["data"] = $input;
$encoded = session_encode();
var_dump(session_decode($encoded));
var_dump($_SESSION);
$iterator++;
};
var_dump(session_destroy());
fclose($fp);
echo "Done";
ob_end_flush();
?>
--EXPECT--
*** Testing session_decode() : basic functionality ***
bool(true)
-- Iteration 1 --
bool(true)
array(1) {
["data"]=>
int(0)
}
-- Iteration 2 --
bool(true)
array(1) {
["data"]=>
int(1)
}
-- Iteration 3 --
bool(true)
array(1) {
["data"]=>
int(12345)
}
-- Iteration 4 --
bool(true)
array(1) {
["data"]=>
int(-2345)
}
-- Iteration 5 --
bool(true)
array(1) {
["data"]=>
float(10.5)
}
-- Iteration 6 --
bool(true)
array(1) {
["data"]=>
float(-10.5)
}
-- Iteration 7 --
bool(true)
array(1) {
["data"]=>
float(123456789000)
}
-- Iteration 8 --
bool(true)
array(1) {
["data"]=>
float(1.23456789E-9)
}
-- Iteration 9 --
bool(true)
array(1) {
["data"]=>
float(0.5)
}
-- Iteration 10 --
bool(true)
array(1) {
["data"]=>
NULL
}
-- Iteration 11 --
bool(true)
array(1) {
["data"]=>
NULL
}
-- Iteration 12 --
bool(true)
array(1) {
["data"]=>
bool(true)
}
-- Iteration 13 --
bool(true)
array(1) {
["data"]=>
bool(false)
}
-- Iteration 14 --
bool(true)
array(1) {
["data"]=>
bool(true)
}
-- Iteration 15 --
bool(true)
array(1) {
["data"]=>
bool(false)
}
-- Iteration 16 --
bool(true)
array(1) {
["data"]=>
string(0) ""
}
-- Iteration 17 --
bool(true)
array(1) {
["data"]=>
string(0) ""
}
-- Iteration 18 --
bool(true)
array(1) {
["data"]=>
string(7) "Nothing"
}
-- Iteration 19 --
bool(true)
array(1) {
["data"]=>
string(7) "Nothing"
}
-- Iteration 20 --
bool(true)
array(1) {
["data"]=>
string(12) "Hello World!"
}
-- Iteration 21 --
bool(true)
array(1) {
["data"]=>
object(classA)#2 (0) {
}
}
-- Iteration 22 --
bool(true)
array(1) {
["data"]=>
NULL
}
-- Iteration 23 --
bool(true)
array(1) {
["data"]=>
NULL
}
-- Iteration 24 --
bool(true)
array(1) {
["data"]=>
int(0)
}
bool(true)
Done
Function Calls
None |
Stats
MD5 | 012436156cc7e48a9f2ad9445a362d78 |
Eval Count | 0 |
Decode Time | 123 ms |