我常用的语句

var_dump($client); //打印变量并且输出变量属性
return json($client); //直接跳出方法体,并返回数据
echo $client['name']; //打印
exit("阻断");//阻断程序向下运行
print_r("文件路径:".$file);
echo "</br>";
printf("行号:%d 函数名:%s \n", __LINE__, __FUNCTION__);

 

PHP执行系统外部命令函数:exec()、passthru()、system()、shell_exec()

 

断点调试是程序开发过程中的一个必不可少的步骤,一些程序的断点调试操作比较简单,只需在编辑器里标记哪行为断点,便可得知程序各个环节的输出结果,例如c#、VB、Delphi等语言。

但是对于​​PHP​​程序的调试来说,就不是这么简单了。本文将谈谈php断点调试的几种方法,对于php新手来说,可能更有参考价值。

首先需要说明的是,php程序调试需要手动编写部分代码,目的是断截程序线程的执行,输出指定环节的结果,就是所谓的断点调试。所以,实际上需要讨论的问题是采用什么断点代码更合适。

die()和exit()

die()和exit()函数都有终止线程的作用,是php断点调试需要使用的最主要的函数,它们也是php程序员使用非常频繁的函数。然而两者又有什么区别呢?在程序调试时需要注意什么问题呢?

die()函数一般与“or”一并使用,写作“or die()”,经常看到这样的语句:

$file = fopen($filename, 'r') or die("抱歉,无法打开: $filename")

or在这里是这样理解的,因为在PHP中并不区分数据类型,所以$file既可以是int也可以bool,所以这样的语句不会报错。但其处理过程可能有些朋友不大明白。其实在大多数的语言中, bool or bool这样的语句中,如果前一个值为真后一个值就不会再判断了。这里也是的,所以如果fopen函数执行正确的话,会返回一个大于0的int值(这其实就是"真"),后面的语句就不会执行了。如果fopen函数执行失败,就会返回false,那么就会判断后面的表达式是否为真了。结果执行了die()之后,不管返回什么,程序都已经停止执行了,并且显示指定的出错信息,也就达到了调试的目的。就这样。

实际上,die和exit是等价的,都是用来终止当前脚本。

php手册对两者的解释如是说:

exit() 函数输出一条消息,并退出当前脚本。该函数是 die() 函数的别名。
die() 函数输出一条消息,并退出当前脚本。该函数是 exit() 函数的别名。

实例:
 <?php $site = "http://www.w3school.com.cn/"; fopen($site,"r") or exit("Unable to connect to $site"); ?>
 <?php $site = "http://www.w3school.com.cn/"; fopen($site,"r") or die("Unable to connect to $site"); ?>

var_dump()和print_r()

var_dump -- 打印变量的相关信息

void var_dump ( mixed expression [, mixed expression [, ...]] )

此函数显示关于一个或多个表达式的结构信息,包括表达式的类型与值。数组将递归展开值,通过缩进显示其结构。

 

提示: 为了防止程序直接将结果输出到浏览器,可以使用输出控制函数(output-control functions)来捕获此函数的输出,并把它们保存到一个例如 string 类型的变量中。   

<?php
$a = array (1, 2, array ("a", "b", "c"));
var_dump ($a);
$b = 3.1;
$c = TRUE;
var_dump($b,$c);
?>

var_dump()可以输出多个变量,如:var_dump($b,$c)

print_r --  打印关于变量的易于理解的信息

bool print_r ( mixed expression [, bool return] )

注: 参数 return 是在 PHP 4.3.0 的时候加上的

print_r() 显示关于一个变量的易于理解的信息。如果给出的是 string、integer 或 float,将打印变量值本身。如果给出的是 array,将会按照一定格式显示键和元素。object 与数组类似。

记住,print_r() 将把数组的指针移到最后边。使用reset() 可让指针回到开始处。

<pre>
<?php
$a = array ('a' => 'apple',
'b' => 'banana',
'c' => array ('x','y','z'));
print_r ($a);
?>
</pre>

上边的代码将输出:

<pre> Array ( [a] => apple [b] => banana [c] => Array ( [0] => x [1] => y [2] => z ) ) </pre>

如果想捕捉 print_r() 的输出,可使用 return 参数。若此参数设为 TRUE,print_r() 将不打印结果(此为默认动作),而是返回其输出。

例子:return 参数示例

<?php
$b = array ('m' => 'monkey',
'foo' => 'bar',
'x' => array ('x', 'y', 'z'));
$results = print_r ($b, true); //$results 包含了 print_r 的输出结果
?>

注: 如果想在 PHP 4.3.0 之前的版本中捕捉 print_r() 的输出,可使用输出控制函数。
注: 在 PHP 4.0.4 之前的版本中,如果给出的 array 或 object 包含了直接或间接指向自身的引用,print_r() 将永远继续下去。print_r($GLOBALS) 就是一个例子,因为 $GLOBALS 自身即是全局变量,其包含了指向自身的引用。

Zend Debugger

 

环境:​​PHP​​ 5.2.5,Zend studio 9,Zend Debugger 5.2.10

zend studio 9 (下载那个 9.0.3): ​​http://www.zendstudio.net/zend-studio-all-in-one-download/​

安装zend debugger

 

  1. zend debugger下载后解压开扔到 d:\zend\ZendDebugger.dll
  2. 然后添加这段到php.ini最后
    [plain]​view plain​​​​copy​
  1. [Zend]
  2. zend_extension_ts="d:/zend/ZendDebugger.dll"
  3. zend_debugger.allow_hosts=127.0.0.1/32,127.0.0.1/24
  4. zend_debugger.expose_remotely=allowed_hosts
  1. 重启Apache
  2. 在你的网站文件夹的根目录下新建一个 a.php ,内容写 <?php phpinfo(); ?>
  3. 打开浏览器,访问 a.php如果出现以下文字表示成功
  4. php断点语句,调试的几种方法_chrome

安装zend debugger toolbar 到 Chrome

  1. 打开chrome 把下载好的  zend debugger toolbar 解压出 zend-debugger-extension.crx 文件拖入到 Chrome 的扩展程序里面安装
  2. 如果浏览器右上角出现这样的一个绿色地球表示成功
    php断点语句,调试的几种方法_chrome_02

zend studio的安装过程不讲

如何调试

在要调试的页面点击 绿地球,然后选 current page 会立即刷新当前页面,并且跳到zend studio里面(首先你的zend studio必须是打开着的状态),如果是 next page 表示是下一个页面调试,就是点击了提交或者是超链接再调试