====== PHP tips ======
===== Instalation tips =====
FIXME
===== Securing PHP code =====
For a start, put disable_functions = "system, exec" in php.ini.
expose_php = Off
display_errors = Off
allow_url_fopen = Off
session.use_trans_sid = 0
session.use_only_cookies = 1
#output_buffering = 4096
#per vhost:
php_admin_flag safe_mode On
php_admin_value open_basedir "/var/www/domain_dir/:/home/"
php_admin_value sendmail_from webmaster@example.com
php_admin_flag display_errors On
php_admin_value safe_mode_include_dir "/usr/share/php/"
# php_admin_value default_charset "UTF-8"
php_admin_value default_charset "windows-1250"
**PHP to secure a setup, a good start is a secure php.ini, for example:**
* disable the Fopen Wrapper, **allow_url_fopen** = Off
* use disable_classes and disable_functions like: - ini_alter, ini_get_all, ini_get, ini_restore, ini_set, php_get_tmpdir, php_ini_scanned_files, php_logo_guid, php_uname, phpcredits, phpinfo, phpversion, putenv, restore_include_path, set_include_path, set_time_limit, version_compare, zend_logo_guid, zend_version, show_source, system, shell_exec, passthru, exec, proc_open, time_limit, version_compare, zend_logo_guid, zend_version, show_source, system, shell_exec, passthru, exec, proc_open etc. etc.
* set **register_globals = off**
* set log_errors = on, error_reporting and error_log
* use **open_basedir** and include_path
* use **safe_mode** if possible
allow_call_time_pass_reference = Off
magic_quotes_gpc = Off
register_long_arrays = Off
register_argc_argv = Off
allow_url_fopen = Off
expose_php = Off
disable_functions = symlink,shell_exec,proc_close,proc_open,dl,passthru,escapeshellarg,escapeshellcmd,openlog, apache_child_terminate,apache_get_modules,apache_get_version,apache_getenv,apache_note,apache_setenv,virtual, phpinfo
=== see also: ===
* **[[http://www.hardened-php.net/suhosin/configuration.html|Suhosin Configuration]]**
* [[http://www.hardened-php.net/|PHP Hardening-Patch]]
* [[http://phpsec.org/projects/guide/|PHP Security Guide]]
* [[http://www.infosecnews.org/pipermail/isn/2007-March/014423.html|[ISN] Secure PHP Configuration]] (local {{014423.html|mirror}})
===== Speeding it up =====
Things that will make your PHP code execute a bit faster .. ''remember that blowt code will still remain blowt code!'', so try to do as much optimization as posible inside algorthyms you are coding.
* See [[http://phplens.com/lens/php-book/optimizing-debugging-php.php|A HOWTO on Optimizing PHP]]
* See [[http://www.zend.com/zend/trick/trick-optimizing-php.php|Optimizing PHP Scripts]]
* See [[http://talks.php.net/show/acc_php/0|Accelerating PHP Applications (International PHP Conference 2004 - Ilia Alshanetsky)]]
* See [[http://www.phpbuilder.com/columns/weerning20021209.php3|Golden Rules for Optimizing Your Pages]]
* See [[http://www.dynamicwebpages.de/count/1540/tutorials/quebeck-conf-slides_performance-workshop_%5Bpdf%5D/|Quebeck-Conf-Slides: Performance-Workshop (PDF)]]
* See [[http://www.dynamicwebpages.de/count/1748/tutorials/zend_php_expo_slides_building_scalable_php_applications_%5Bpdf%5D/|Zend/PHP Expo Slides: Building Scalable PHP Applications (PDF)]]
==== Zend Optimizer ====
=== Instalation ===
Get Zend optimizer from [[http://www.zend.com/products/zend_optimizer]] or [[:zend|here (Local mirrors)]]
**''php.ini''**
[Zend]
zend_optimizer.enable_loader=0
zend_optimizer.disable_licensing=0
zend_optimizer.licence_path=0
=== Configuration ===
**''php.ini''**
[Zend]
zend_optimizer.optimization_level=15
zend_extension_manager.optimizer=/usr/local/Zend/lib/Optimizer-2.1.0
zend_extension_manager.optimizer_ts=/usr/local/Zend/lib/Optimizer_TS-2.1.0
zend_extension=/usr/local/Zend/lib/ZendExtensionManager.so
zend_extension_ts=/usr/local/Zend/lib/ZendExtensionManager_TS.so
''Fix the paths to the Zend libraries''
==== EAccelerator ====
=== Instalation ===
* Download source from [[http://eaccelerator.net/]]
* Requirements: apache 1.3, apache 2.0 (prefork), mod_php4/5, autoconf, automake, libtool, m4
export PHP_PREFIX="/usr"
$PHP_PREFIX/bin/phpize
./configure --enable-eaccelerator=shared --with-php-config=$PHP_PREFIX/bin/php-config
make
make install
--without-eaccelerator-use-inode [bug with open_basedir - safe mode]
* See [[http://eaccelerator.net/SourceInstallationUk|Instalation from source]]
=== Eaccelerator with Zend Optimizer ===
**''/etc/php/*/php.ini''**
[EAccelerator]
zend_extension="/usr/local/lib/php/extensions/no-debug-non-zts-20020429/eaccelerator.so"
eaccelerator.shm_size="32"
eaccelerator.cache_dir="/tmp/eaccelerator" ; if you use disk cache - folder MUST exist
eaccelerator.enable="1"
eaccelerator.optimizer="1"
eaccelerator.check_mtime="1"
eaccelerator.debug="0"
eaccelerator.filter=""
eaccelerator.shm_max="0"
eaccelerator.shm_ttl="0"
eaccelerator.shm_prune_period="0"
eaccelerator.shm_only="1" ; doesn't save cache to disk (cache_dir)
eaccelerator.compress="0"
eaccelerator.compress_level="9"
[Zend]
zend_optimizer.optimization_level=15
zend_extension_manager.optimizer=/usr/local/Zend/lib/Optimizer-2.5.10
zend_extension_manager.optimizer_ts=/usr/local/Zend/lib/Optimizer_TS-2.5.10
zend_optimizer.version=2.5.10a
zend_extension=/usr/local/Zend/lib/ZendExtensionManager.so
zend_extension_ts=/usr/local/Zend/lib/ZendExtensionManager_TS.so
**Be sure to fix the PATH to Zend and eaccelerator libraries**
eaccelerator
php.ini tricks
[[Zend]]