background image

PHP 程序员的优化调试技术和技巧

     本文介绍调试 PHP 应用程序的各种方法,包括在 Apache and PHP 中打开错误报
告,以及通过在一个简单的

 PHP 脚本中放置策略性的 print 语句,找到更困难的 bug 的

源头。还会介绍用于

 Eclipse 的 PHPEclipse 插件,这是一个灵活的开发环境,具有实时

语法解析能力,还会介绍

 PHPEclipse 的 DBG 调试器扩展。 

  简介
  有许多

 PHP 调试技术可以在编码的时候节约大量时间。一个有效却很基本的调试技术

就是打开错误报告。另一个略微高级一点的技术包括使用

 print 语句,通过显示在屏幕上实

际出现的内容,有助于精确地找出更难发现的

 bug。PHPEclipse 是一个 Eclipse 插件,

能够强调常见的语法错误,可以与调试器结合起来用于设置断点。
  设置
  要学习本文描述的概念,需要

 PHP、Web 服务器和 Eclipse。调试器扩展支持的 PHP 

版本是

 V5.0.3。 

  我们需要一个

 Web 服务器来解析用 PHP 创建的页面并把它们显示到浏览器。本文中

使用的是

 Apache2。但是,任何 Web 服务器都可以满足要求。 

  要利用本文中介绍的一些调试技术,需要安装

 Eclipse V3.1.1 和插件 PHPEclipse 

V1.1.8。由于 Eclipse 要求 Java  技术,所以还要下载它。 
  还需要

 PHP 的调试器扩展模块。安装它略有些麻烦。请仔细跟随安装调试器扩展的操

作说明。现在,先在

 php.ini 文件中注释掉那些要求装入和配置 PHP 扩展的行。在需要使

用调试器的时候,再取消注释。
  请参阅

 参考资料 获得下载信息。现在介绍出错消息。

  出错消息
  出错消息是作为开发人员的第一道防线。谁都不想在一台没有配置成显示出错消息的服
务器上用

 PHP 开发代码。但是,请记住,当代码调试完成,准备运行的时候,应当确保关

闭了错误报告,因为不希望站点的访问者看到出错消息,因为这会给他们提供足够的信息
来利用站点的弱点并黑掉站点。
  也可以用出错消息为自己服务,因为它们会显示抛出或生成错误的正确代码行。这样,
调试就变成在浏览器上查看生成的错误所显示的行号,并在代码中检查这一行。稍后,将会
看到

 PHPEclipse 插件通过即时地给语法错误加下划线并在保存文件时用红色 “x” 标注语

法错误,可在开发和调试过程中提供极大的帮助。
  先来看如何在

 php.ini 文件中开启错误报告并设置错误报告的级别。然后将学习如何在 

Apache 的配置文件中覆盖这些设置。
  

PHP 的错误报告

  

php.ini 文件中有许多配置设置。您应当已经设置好自己的 php.ini 文件并把它放在合

适的目录中,就像在

 Linux 上安装 PHP 和 Apache 2 的文档说明中所示的那样(请参阅 

参考资料)。在调试

 PHP 应用程序时,应当知道两个配置变量。下面是这两个变量及其默

认值:
 
display_errors = Off 
error_reporting = E_ALL 
  通过在

 php.ini 文件中搜索它们,可以发现这两个变量当前的默认值。display_errors 

变量的目的很明显

 —— 它告诉 PHP 是否显示错误。默认值是 Off。但是,要让开发过程更