3v4l.org

run code in 300+ PHP versions simultaneously
<?php include('/etc/profile'); $myfile = fopen("/tmp/test.txt", "w") or die("Unable to open file!"); $txt = "John Doe\n"; fwrite($myfile, $txt); $txt = "Jane Doe\n"; fwrite($myfile, $txt); fclose($myfile); // current directory echo getcwd() . "\n"; chdir('/tmp'); // current directory echo getcwd() . "\n"; $dir = '/usr/local/'; $files1 = scandir($dir); $files2 = scandir($dir, 1); print_r($files1); print_r($files2);
Output for 8.0.0 - 8.0.30, 8.1.0 - 8.1.28, 8.2.0 - 8.2.18, 8.3.0 - 8.3.4, 8.3.6
# /etc/profile # Set our umask umask 022 # Append "$1" to $PATH when not already in. # This function API is accessible to scripts in /etc/profile.d append_path () { case ":$PATH:" in *:"$1":*) ;; *) PATH="${PATH:+$PATH:}$1" esac } # Append our default paths append_path '/usr/local/sbin' append_path '/usr/local/bin' append_path '/usr/bin' # Force PATH to be environment export PATH # Load profiles from /etc/profile.d if test -d /etc/profile.d/; then for profile in /etc/profile.d/*.sh; do test -r "$profile" && . "$profile" done unset profile fi # Unload our profile API functions unset -f append_path # Source global bash config, when interactive but not posix or sh mode if test "$BASH" &&\ test "$PS1" &&\ test -z "$POSIXLY_CORRECT" &&\ test "${0#-}" != sh &&\ test -r /etc/bash.bashrc then . /etc/bash.bashrc fi # Termcap is outdated, old, and crusty, kill it. unset TERMCAP # Man is much better than us at figuring this out unset MANPATH / /tmp Warning: scandir(): open_basedir restriction in effect. File(/usr/local/) is not within the allowed path(s): (/tmp:/in:/etc) in /in/g5ahQ on line 19 Warning: scandir(/usr/local/): Failed to open directory: Operation not permitted in /in/g5ahQ on line 19 Warning: scandir(): (errno 1): Operation not permitted in /in/g5ahQ on line 19 Warning: scandir(): open_basedir restriction in effect. File(/usr/local/) is not within the allowed path(s): (/tmp:/in:/etc) in /in/g5ahQ on line 20 Warning: scandir(/usr/local/): Failed to open directory: Operation not permitted in /in/g5ahQ on line 20 Warning: scandir(): (errno 1): Operation not permitted in /in/g5ahQ on line 20
Output for 8.3.5
Warning: PHP Startup: Unable to load dynamic library 'sodium.so' (tried: /usr/lib/php/8.3.5/modules/sodium.so (libsodium.so.23: cannot open shared object file: No such file or directory), /usr/lib/php/8.3.5/modules/sodium.so.so (/usr/lib/php/8.3.5/modules/sodium.so.so: cannot open shared object file: No such file or directory)) in Unknown on line 0 # /etc/profile # Set our umask umask 022 # Append "$1" to $PATH when not already in. # This function API is accessible to scripts in /etc/profile.d append_path () { case ":$PATH:" in *:"$1":*) ;; *) PATH="${PATH:+$PATH:}$1" esac } # Append our default paths append_path '/usr/local/sbin' append_path '/usr/local/bin' append_path '/usr/bin' # Force PATH to be environment export PATH # Load profiles from /etc/profile.d if test -d /etc/profile.d/; then for profile in /etc/profile.d/*.sh; do test -r "$profile" && . "$profile" done unset profile fi # Unload our profile API functions unset -f append_path # Source global bash config, when interactive but not posix or sh mode if test "$BASH" &&\ test "$PS1" &&\ test -z "$POSIXLY_CORRECT" &&\ test "${0#-}" != sh &&\ test -r /etc/bash.bashrc then . /etc/bash.bashrc fi # Termcap is outdated, old, and crusty, kill it. unset TERMCAP # Man is much better than us at figuring this out unset MANPATH / /tmp Warning: scandir(): open_basedir restriction in effect. File(/usr/local/) is not within the allowed path(s): (/tmp:/in:/etc) in /in/g5ahQ on line 19 Warning: scandir(/usr/local/): Failed to open directory: Operation not permitted in /in/g5ahQ on line 19 Warning: scandir(): (errno 1): Operation not permitted in /in/g5ahQ on line 19 Warning: scandir(): open_basedir restriction in effect. File(/usr/local/) is not within the allowed path(s): (/tmp:/in:/etc) in /in/g5ahQ on line 20 Warning: scandir(/usr/local/): Failed to open directory: Operation not permitted in /in/g5ahQ on line 20 Warning: scandir(): (errno 1): Operation not permitted in /in/g5ahQ on line 20
Output for 7.4.33
# /etc/profile # Set our umask umask 022 # Append "$1" to $PATH when not already in. # This function API is accessible to scripts in /etc/profile.d append_path () { case ":$PATH:" in *:"$1":*) ;; *) PATH="${PATH:+$PATH:}$1" esac } # Append our default paths append_path '/usr/local/sbin' append_path '/usr/local/bin' append_path '/usr/bin' # Force PATH to be environment export PATH # Load profiles from /etc/profile.d if test -d /etc/profile.d/; then for profile in /etc/profile.d/*.sh; do test -r "$profile" && . "$profile" done unset profile fi # Unload our profile API functions unset -f append_path # Source global bash config, when interactive but not posix or sh mode if test "$BASH" &&\ test "$PS1" &&\ test -z "$POSIXLY_CORRECT" &&\ test "${0#-}" != sh &&\ test -r /etc/bash.bashrc then . /etc/bash.bashrc fi # Termcap is outdated, old, and crusty, kill it. unset TERMCAP # Man is much better than us at figuring this out unset MANPATH / /tmp Array ( [0] => . [1] => .. [2] => bin [3] => etc [4] => games [5] => include [6] => lib [7] => man [8] => sbin [9] => share [10] => src ) Array ( [0] => src [1] => share [2] => sbin [3] => man [4] => lib [5] => include [6] => games [7] => etc [8] => bin [9] => .. [10] => . )
Output for 5.6.0 - 5.6.40, 7.0.0 - 7.0.33, 7.1.0 - 7.1.33, 7.2.0 - 7.2.34, 7.3.0 - 7.3.33, 7.4.0 - 7.4.32
# /etc/profile # Set our umask umask 022 # Append "$1" to $PATH when not already in. # This function API is accessible to scripts in /etc/profile.d append_path () { case ":$PATH:" in *:"$1":*) ;; *) PATH="${PATH:+$PATH:}$1" esac } # Append our default paths append_path '/usr/local/sbin' append_path '/usr/local/bin' append_path '/usr/bin' # Force PATH to be environment export PATH # Load profiles from /etc/profile.d if test -d /etc/profile.d/; then for profile in /etc/profile.d/*.sh; do test -r "$profile" && . "$profile" done unset profile fi # Unload our profile API functions unset -f append_path # Source global bash config, when interactive but not posix or sh mode if test "$BASH" &&\ test "$PS1" &&\ test -z "$POSIXLY_CORRECT" &&\ test "${0#-}" != sh &&\ test -r /etc/bash.bashrc then . /etc/bash.bashrc fi # Termcap is outdated, old, and crusty, kill it. unset TERMCAP # Man is much better than us at figuring this out unset MANPATH / /tmp Warning: scandir(): open_basedir restriction in effect. File(/usr/local/) is not within the allowed path(s): (/tmp:/in:/etc) in /in/g5ahQ on line 19 Warning: scandir(/usr/local/): failed to open dir: Operation not permitted in /in/g5ahQ on line 19 Warning: scandir(): (errno 1): Operation not permitted in /in/g5ahQ on line 19 Warning: scandir(): open_basedir restriction in effect. File(/usr/local/) is not within the allowed path(s): (/tmp:/in:/etc) in /in/g5ahQ on line 20 Warning: scandir(/usr/local/): failed to open dir: Operation not permitted in /in/g5ahQ on line 20 Warning: scandir(): (errno 1): Operation not permitted in /in/g5ahQ on line 20

preferences:
244.85 ms | 406 KiB | 300 Q