Pragmatic PHP |
data:image/s3,"s3://crabby-images/d9a11/d9a114dec2b350032067777ad644a3269104a2f7" alt="" |
2025-02-24 |
data:image/s3,"s3://crabby-images/cbdbc/cbdbc663ccb2a17cae15758c2ff4d217ad486bfd" alt="" |
data:image/s3,"s3://crabby-images/40708/4070823866ea369307908f1a4d9063006e0693e6" alt="" |
data:image/s3,"s3://crabby-images/cbdbc/cbdbc663ccb2a17cae15758c2ff4d217ad486bfd" alt=""
6 |
data:image/s3,"s3://crabby-images/23e9d/23e9d258f51d1fa168124f6453976ce9422dc398" alt="" |
data:image/s3,"s3://crabby-images/cbdbc/cbdbc663ccb2a17cae15758c2ff4d217ad486bfd" alt="" |
Security in a web application boils down to always checking any
user-supplied input data.
Exploits
- • readfile($filename)
- • system($cmd)
- • file uploads into document_root
- • XSS - Cross Site Scripting hacks
Input Filter hook
PHP_MINIT_FUNCTION(my_input_filter)
{
sapi_register_input_filter(my_sapi_input_filter);
return SUCCESS;
}
For a complete example, see README.input_filter in the PHP 5 source distribution and pecl/filter.
For PHP4, you will have to patch your source with http://lerdorf.com/php/input_filter.txt