日期:2011-12-07  浏览次数:20452 次

 

  先说PHP的错误信息,来自PHP100论坛

  PHP的错误信息由一下几部分构成

  {错误类型}: {错误原因} in {错误文件} on {错误行数}

  说明了在哪个文件的哪一行中因何种原因出现了何种错误。

  常见的错误类型一般有下面几种:

  Parse error(解析错误)一般都伴随着Syntax errors(句法错误) ,说明你的程序不符合PHP的语法。

  它是级别最高的错误,整个脚本根本不会被执行。

  一般都是由一个表达式缺少";" 或各种括号引号不成对引起的。看详细的信息就能知道问题的所在。

  一般句法错误都会给你提示一个解析器代号,告诉你出现的问题是在哪里。比如:

  Parse error: syntax error, unexpected T_STRING in xxx.php on line 9

  T_STRING 是一个解析器代号,顾名思义,它代表字符串,很多错误原因都会带解析器代号。通过它你可以更直接的了解到错误的原因。

  unexpected意思是非预期的,换句话说也就是多余的。

  更多解析器代号请参考:http://www.php.net/manual/zh/tokens.php 或php手册 英文版中叫:List of Parser Tokens 中文版中叫:解析器代号列表

  上面的错误的意思是说你的第九行有一个非预期的字符串。

  我的代码:

  1-7: 略

  8 : test(array('a'))

  9 : xxx();

  10 : >

  这个问题如何解决呢?把第九行的xxx删掉,的确符合PHP语法了。

  但是那不是我想要的,实际上是我的第8行缺少了一个";",解决办法是在第8行结尾加分号。

  注意:这个例子还说明了一个问题,错误报告说是哪行,问题不一定就非在哪行,也可能是它的前面一行或几行造成的。最典型的例子是某程序提示出错行数在文件的最后一行,你去看,发现那行除了“>”以外没有别的字符,这种情况一般是缺少引号导致的。你要往前面找不成对的引号或者别的什么标点。如果你非要抬杠,认准了行号不松口,那就不是php的问题了。

  Fatal Error(致命错误),仅次于Parsing Error的错误,执行到发生错误的行时,脚本会终止运行。

  在程序符合PHP语法的基础上,使用了未定义的函数,或require一个不存在的文件,死循环导致程序执行超时,都会导致fatal error。

  一般表现为:

  Fatal Error: Call to undefined function func() in php100.php on line 某某

  就是说在某某行你调用了一个未定义的func函数,这时候一般就是看你是否忘了包含该包含的文件,是否写错了函数名,是否写错了文件名。(PHP100.com)

  Warning(警告),比致命错误级别稍低,但程序不会因为脚本错误而终止。

  一般出现在include一个不存在的文件,或者一个程序需要一个参数,但是你没传参数,并且你也没指定参数的默认值。

  Warning视情况可以避免出现,实在没法避免,可以加@强行屏蔽。

  Notice(通知),级别最低,一般可以无视,不会影响到脚本的运行。多数发生在变量或数组下标未定义的情况。

  注意:多数notice都可忽略,但是少数的notice也可能会反映出比较严重的问题。

  比如 Notice: Undefined variable: sql in xxx.php on line xx

  你看到有个变量"sql"未定义,这就可能很危险了,在register_globals=on的情况下,没准这个错误直接就成为了别人操作数据库的后门。

  此外还有一些别的类型的错误,平时不常见,我就不多说了。

  总结

  综上所述,PHP的错误提示会告诉我们很多事情,为我们查找错误提供了极大的方便。好好利用它,会大大的提高我们的工作效率和工作质量。

  不过,它带来好处的同时,也可能会透露服务器的敏感信息,容易让攻击者发现服务器的漏洞。

  php开发环境一定要打开全部错误提示,打开错误显示。最大限度的减少事故的发生。

  生产环境千万要把错误显示关闭,改用日志来记录错误。别给有心人以可乘之机。