3v4l.org

run code in 300+ PHP versions simultaneously
<?php class MySessionHandler implements \SessionHandlerInterface { public $messages = array(); public function open($savePath, $sessionName) { $this->messages[] = 'open ' . $sessionName; } public function close() { $this->messages[] = 'close'; } public function read($id) { $this->messages[] = 'read ' . $id; } public function write($id, $data) { $this->messages[] = 'write ' . $id . ': ' . $data; } public function destroy($id) { $this->messages[] = 'destroy ' . $id; } public function gc($maxlifetime) { $this->messages[] = 'gc ' . var_export($maxlifetime, true); } public function __destruct() { var_dump($this->messages); } } $handler = new MySessionHandler(); $handler->messages[] = 'session_status(): ' . session_status(); $handler->messages[] = 'session_id before start: ' . var_export(session_id(), true); session_set_save_handler($handler, true); $handler->messages[] = 'isset($_SESSION): ' . var_export(isset($_SESSION), true); $_SESSION['before'] = 'start'; $handler->messages[] = 'headers_sent: ' . var_export(headers_sent(), true); echo 'S'; session_start(); $handler->messages[] = 'headers_sent: ' . var_export(headers_sent(), true); $handler->messages[] = 'headers_list: ' . var_export(headers_list(), true); $_SESSION['foo'] = 'bar'; $handler->messages[] = 'current session_id: ' . session_id(); session_regenerate_id(true); $handler->messages[] = 'current session_id: ' . session_id(); session_write_close(); $handler->messages[] = '$_SESSION after close: ' . var_export($_SESSION, true); $handler->messages[] = 'session_id after close: ' . session_id(); session_start(); session_destroy(); $handler->messages[] = '$_SESSION after destroy: ' . var_export($_SESSION, true); $handler->messages[] = 'current session_id: ' . var_export(session_id(), true); session_id('explicit-session-id'); session_start(); $_SESSION['john'] = 'doe';
Finding entry points
Branch analysis from position: 0
1 jumps found. (Code = 62) Position 1 = -2
filename:       /in/qfFTd
function name:  (null)
number of ops:  136
compiled vars:  !0 = $handler
line      #* E I O op                           fetch          ext  return  operands
-------------------------------------------------------------------------------------
    4     0  E >   DECLARE_CLASS                                            'mysessionhandler'
   45     1        NEW                                              $1      'MySessionHandler'
          2        DO_FCALL                                      0          
          3        ASSIGN                                                   !0, $1
   46     4        INIT_FCALL                                               'session_status'
          5        DO_ICALL                                         $6      
          6        CONCAT                                           ~7      'session_status%28%29%3A+', $6
          7        FETCH_OBJ_W                                      $4      !0, 'messages'
          8        ASSIGN_DIM                                               $4
          9        OP_DATA                                                  ~7
   47    10        INIT_FCALL                                               'var_export'
         11        INIT_FCALL                                               'session_id'
         12        DO_ICALL                                         $10     
         13        SEND_VAR                                                 $10
         14        SEND_VAL                                                 <true>
         15        DO_ICALL                                         $11     
         16        CONCAT                                           ~12     'session_id+before+start%3A+', $11
         17        FETCH_OBJ_W                                      $8      !0, 'messages'
         18        ASSIGN_DIM                                               $8
         19        OP_DATA                                                  ~12
   48    20        INIT_FCALL                                               'session_set_save_handler'
         21        SEND_VAR                                                 !0
         22        SEND_VAL                                                 <true>
         23        DO_ICALL                                                 
   50    24        INIT_FCALL                                               'var_export'
         25        ISSET_ISEMPTY_VAR                             2  ~16     '_SESSION'
         26        SEND_VAL                                                 ~16
         27        SEND_VAL                                                 <true>
         28        DO_ICALL                                         $17     
         29        CONCAT                                           ~18     'isset%28%24_SESSION%29%3A+', $17
         30        FETCH_OBJ_W                                      $14     !0, 'messages'
         31        ASSIGN_DIM                                               $14
         32        OP_DATA                                                  ~18
   51    33        FETCH_W                      global              $19     '_SESSION'
         34        ASSIGN_DIM                                               $19, 'before'
         35        OP_DATA                                                  'start'
   53    36        INIT_FCALL                                               'var_export'
         37        INIT_FCALL                                               'headers_sent'
         38        DO_ICALL                                         $23     
         39        SEND_VAR                                                 $23
         40        SEND_VAL                                                 <true>
         41        DO_ICALL                                         $24     
         42        CONCAT                                           ~25     'headers_sent%3A+', $24
         43        FETCH_OBJ_W                                      $21     !0, 'messages'
         44        ASSIGN_DIM                                               $21
         45        OP_DATA                                                  ~25
   54    46        ECHO                                                     'S'
   55    47        INIT_FCALL                                               'session_start'
         48        DO_ICALL                                                 
   57    49        INIT_FCALL                                               'var_export'
         50        INIT_FCALL                                               'headers_sent'
         51        DO_ICALL                                         $29     
         52        SEND_VAR                                                 $29
         53        SEND_VAL                                                 <true>
         54        DO_ICALL                                         $30     
         55        CONCAT                                           ~31     'headers_sent%3A+', $30
         56        FETCH_OBJ_W                                      $27     !0, 'messages'
         57        ASSIGN_DIM                                               $27
         58        OP_DATA                                                  ~31
   58    59        INIT_FCALL                                               'var_export'
         60        INIT_FCALL                                               'headers_list'
         61        DO_ICALL                                         $34     
         62        SEND_VAR                                                 $34
         63        SEND_VAL                                                 <true>
         64        DO_ICALL                                         $35     
         65        CONCAT                                           ~36     'headers_list%3A+', $35
         66        FETCH_OBJ_W                                      $32     !0, 'messages'
         67        ASSIGN_DIM                                               $32
         68        OP_DATA                                                  ~36
   60    69        FETCH_W                      global              $37     '_SESSION'
         70        ASSIGN_DIM                                               $37, 'foo'
         71        OP_DATA                                                  'bar'
   62    72        INIT_FCALL                                               'session_id'
         73        DO_ICALL                                         $41     
         74        CONCAT                                           ~42     'current+session_id%3A+', $41
         75        FETCH_OBJ_W                                      $39     !0, 'messages'
         76        ASSIGN_DIM                                               $39
         77        OP_DATA                                                  ~42
   63    78        INIT_FCALL                                               'session_regenerate_id'
         79        SEND_VAL                                                 <true>
         80        DO_ICALL                                                 
   64    81        INIT_FCALL                                               'session_id'
         82        DO_ICALL                                         $46     
         83        CONCAT                                           ~47     'current+session_id%3A+', $46
         84        FETCH_OBJ_W                                      $44     !0, 'messages'
         85        ASSIGN_DIM                                               $44
         86        OP_DATA                                                  ~47
   65    87        INIT_FCALL                                               'session_write_close'
         88        DO_ICALL                                                 
   67    89        INIT_FCALL                                               'var_export'
         90        FETCH_R                      global              ~51     '_SESSION'
         91        SEND_VAL                                                 ~51
         92        SEND_VAL                                                 <true>
         93        DO_ICALL                                         $52     
         94        CONCAT                                           ~53     '%24_SESSION+after+close%3A+', $52
         95        FETCH_OBJ_W                                      $49     !0, 'messages'
         96        ASSIGN_DIM                                               $49
         97        OP_DATA                                                  ~53
   68    98        INIT_FCALL                                               'session_id'
         99        DO_ICALL                                         $56     
        100        CONCAT                                           ~57     'session_id+after+close%3A+', $56
        101        FETCH_OBJ_W                                      $54     !0, 'messages'
        102        ASSIGN_DIM                                               $54
        103        OP_DATA                                                  ~57
   70   104        INIT_FCALL                                               'session_start'
        105        DO_ICALL                                                 
   71   106        INIT_FCALL                                               'session_destroy'
        107        DO_ICALL                                                 
   72   108        INIT_FCALL                                               'var_export'
        109        FETCH_R                      global              ~62     '_SESSION'
        110        SEND_VAL                                                 ~62
        111        SEND_VAL                                                 <true>
        112        DO_ICALL                                         $63     
        113        CONCAT                                           ~64     '%24_SESSION+after+destroy%3A+', $63
        114        FETCH_OBJ_W                                      $60     !0, 'messages'
        115        ASSIGN_DIM                                               $60
        116        OP_DATA                                                  ~64
   73   117        INIT_FCALL                                               'var_export'
        118        INIT_FCALL                                               'session_id'
        119        DO_ICALL                                         $67     
        120        SEND_VAR                                                 $67
        121        SEND_VAL                                                 <true>
        122        DO_ICALL                                         $68     
        123        CONCAT                                           ~69     'current+session_id%3A+', $68
        124        FETCH_OBJ_W                                      $65     !0, 'messages'
        125        ASSIGN_DIM                                               $65
        126        OP_DATA                                                  ~69
   75   127        INIT_FCALL                                               'session_id'
        128        SEND_VAL                                                 'explicit-session-id'
        129        DO_ICALL                                                 
   76   130        INIT_FCALL                                               'session_start'
        131        DO_ICALL                                                 
   77   132        FETCH_W                      global              $72     '_SESSION'
        133        ASSIGN_DIM                                               $72, 'john'
        134        OP_DATA                                                  'doe'
        135      > RETURN                                                   1

Class MySessionHandler:
Function open:
Finding entry points
Branch analysis from position: 0
1 jumps found. (Code = 62) Position 1 = -2
filename:       /in/qfFTd
function name:  open
number of ops:  7
compiled vars:  !0 = $savePath, !1 = $sessionName
line      #* E I O op                           fetch          ext  return  operands
-------------------------------------------------------------------------------------
    8     0  E >   RECV                                             !0      
          1        RECV                                             !1      
   10     2        CONCAT                                           ~4      'open+', !1
          3        FETCH_OBJ_W                                      $2      'messages'
          4        ASSIGN_DIM                                               $2
          5        OP_DATA                                                  ~4
   11     6      > RETURN                                                   null

End of function open

Function close:
Finding entry points
Branch analysis from position: 0
1 jumps found. (Code = 62) Position 1 = -2
filename:       /in/qfFTd
function name:  close
number of ops:  4
compiled vars:  none
line      #* E I O op                           fetch          ext  return  operands
-------------------------------------------------------------------------------------
   15     0  E >   FETCH_OBJ_W                                      $0      'messages'
          1        ASSIGN_DIM                                               $0
          2        OP_DATA                                                  'close'
   16     3      > RETURN                                                   null

End of function close

Function read:
Finding entry points
Branch analysis from position: 0
1 jumps found. (Code = 62) Position 1 = -2
filename:       /in/qfFTd
function name:  read
number of ops:  6
compiled vars:  !0 = $id
line      #* E I O op                           fetch          ext  return  operands
-------------------------------------------------------------------------------------
   18     0  E >   RECV                                             !0      
   20     1        CONCAT                                           ~3      'read+', !0
          2        FETCH_OBJ_W                                      $1      'messages'
          3        ASSIGN_DIM                                               $1
          4        OP_DATA                                                  ~3
   21     5      > RETURN                                                   null

End of function read

Function write:
Finding entry points
Branch analysis from position: 0
1 jumps found. (Code = 62) Position 1 = -2
filename:       /in/qfFTd
function name:  write
number of ops:  9
compiled vars:  !0 = $id, !1 = $data
line      #* E I O op                           fetch          ext  return  operands
-------------------------------------------------------------------------------------
   23     0  E >   RECV                                             !0      
          1        RECV                                             !1      
   25     2        CONCAT                                           ~4      'write+', !0
          3        CONCAT                                           ~5      ~4, '%3A+'
          4        CONCAT                                           ~6      ~5, !1
          5        FETCH_OBJ_W                                      $2      'messages'
          6        ASSIGN_DIM                                               $2
          7        OP_DATA                                                  ~6
   26     8      > RETURN                                                   null

End of function write

Function destroy:
Finding entry points
Branch analysis from position: 0
1 jumps found. (Code = 62) Position 1 = -2
filename:       /in/qfFTd
function name:  destroy
number of ops:  6
compiled vars:  !0 = $id
line      #* E I O op                           fetch          ext  return  operands
-------------------------------------------------------------------------------------
   28     0  E >   RECV                                             !0      
   30     1        CONCAT                                           ~3      'destroy+', !0
          2        FETCH_OBJ_W                                      $1      'messages'
          3        ASSIGN_DIM                                               $1
          4        OP_DATA                                                  ~3
   31     5      > RETURN                                                   null

End of function destroy

Function gc:
Finding entry points
Branch analysis from position: 0
1 jumps found. (Code = 62) Position 1 = -2
filename:       /in/qfFTd
function name:  gc
number of ops:  10
compiled vars:  !0 = $maxlifetime
line      #* E I O op                           fetch          ext  return  operands
-------------------------------------------------------------------------------------
   33     0  E >   RECV                                             !0      
   35     1        INIT_FCALL                                               'var_export'
          2        SEND_VAR                                                 !0
          3        SEND_VAL                                                 <true>
          4        DO_ICALL                                         $3      
          5        CONCAT                                           ~4      'gc+', $3
          6        FETCH_OBJ_W                                      $1      'messages'
          7        ASSIGN_DIM                                               $1
          8        OP_DATA                                                  ~4
   36     9      > RETURN                                                   null

End of function gc

Function __destruct:
Finding entry points
Branch analysis from position: 0
1 jumps found. (Code = 62) Position 1 = -2
filename:       /in/qfFTd
function name:  __destruct
number of ops:  5
compiled vars:  none
line      #* E I O op                           fetch          ext  return  operands
-------------------------------------------------------------------------------------
   40     0  E >   INIT_FCALL                                               'var_dump'
          1        FETCH_OBJ_R                                      ~0      'messages'
          2        SEND_VAL                                                 ~0
          3        DO_ICALL                                                 
   41     4      > RETURN                                                   null

End of function __destruct

End of class MySessionHandler.

Generated using Vulcan Logic Dumper, using php 8.0.0


preferences:
158.58 ms | 1412 KiB | 35 Q