PHP安全编程:不要让不相关的人看到报错信息

没有不会犯错的开发者,PHP的错误报告功能可以协助你确认和定位这些错误,可以提供的这些错误的详细描述,但如果被恶意攻击者看到,这就不妙了。不能让大众看到报错信息,这一点很重要。做到这一点很容易,只要关闭display_errors,当然如果您希望得到出错信息,可以打开log_errors选项,并在error_log选项中设置出错日志文件的保存路径。

由于出错报告的级别设定可以导致有些错误无法发现,您至少需要把error_reporting设为E_ALL。E_ALL | E_STRICT 是最高的设置,提供向下兼容的建议,如不建议使用的提示。

所有的出错报告级别可以在任意级别进行修改,所以您如果使用的是共享的主机,没有权限对php.ini, httpd.conf, 或 .htaccess等配置文件进行更改时,您可以在程序中运行出错报告级别配置语句:

[php]   view plain copy
  1. <?php  
  2.   
  3. ini_set('error_reporting', E_ALL | E_STRICT);  
  4. ini_set('display_errors''Off');  
  5. ini_set('log_errors''On');  
  6. ini_set('error_log''/usr/local/apache/logs/error_log');  
  7.   
  8. ?>  

http://php.net/manual/ini.php  对php.ini的选项配置作了详尽的说明。

set_error_handler() 函数

PHP还允许您通过 set_error_handler( ) 函数指定您自已的出错处理函数:

[php]   view plain copy
  1. <?php  
  2. set_error_handler('my_error_handler');  
  3. ?>  


上面程序指定了您自已的出错处理函数my_error_handler()。下面是一个实际使用的示例:

[php]   view plain copy
  1. <?php  
  2.   
  3. function my_error_handler($number$string$file$line$context)  
  4. {  
  5.   $error = "=  ==  ==  ==  ==\nPHP ERROR\n=  ==  ==  ==  ==\n";  
  6.   $error .= "Number: [$number]\n";  
  7.   $error .= "String: [$string]\n";  
  8.   $error .= "File:   [$file]\n";  
  9.   $error .= "Line:   [$line]\n";  
  10.   $error .= "Context:\n" . print_r($context, TRUE) . "\n\n";  
  11.   
  12.   error_log($error, 3, '/usr/local/apache/logs/error_log');  
  13. }  
  14.   
  15. ?>  


PHP 5还允许向set_error_handler( )传递第二个参数以限定在什么出错情况下执行出定义的出错处理函数。比如,现在建立一个处理告警级别(warning)错误的函数:

[php]   view plain copy
  1. <?php  
  2. set_error_handler('my_warning_handler', E_WARNING);  
  3. ?>  


PHP5还提供了异常处理机制,详见http://php.net/exceptions
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值