Php代码控制错误提示级别

有时候在使用cli执行php脚本时会弹出一些杂乱的warning和notice,虽然有助于调试,但有时会影响结果输出.所以需要对错误输出级别进行设置.

error_reporting

error_reporting() 函数能够在运行时设置 error_reporting 指令。 PHP 有诸多错误级别,使用该函数可以设置在脚本运行时的级别。 如果没有设置可选参数 level, error_reporting() 仅会返回当前的错误报告级别。

1        E_ERROR        报告运行时的致命错误
2        E_WARNING        报告运行的非致命错误

4        E_PARSE        报告解析错误
8        E_NOTICE        报告通告,注意,表示所做的事情可能是错误的.
16           E_CORE_ERROR        报告PHP引擎启动失败
32           E_CORE_WARNING    报告PHP引擎启动时非致命错误

64           E_COMPILE_ERROR    报告编译错误
128         E_COMPILE_WARNING    报告编译时出现的非致命错误

256         E_USER_ERROR        报告用户触发的错误
512         E_USER_WARNING    报告用户触发的警告

1024          E_USER_NOTICE        报告用户触发的通告
2047       E_ALL            报告所有的错误和警告
2048       E_STRICT        报告不赞成的用法和不推荐的行为

错误级别的使用

  • error_reporting的参数可以使用数值和常量,推荐使用常量
  • error_reporting可以使用|设置多个错误级别,指定输出某些错误信息
  • error_reporting(E_ERROR | E_NOTICE | E_PARSE); //这样是不会显示Warning错误的
//不显示任何错误
//error_reporting(0);

//只显示Error级别的错误
//error_reporting(1);
//error_reporting(E_ERROR);

//报告运行时错误
//任意数目的以上选项都可以用“或”来连接(用 OR 或 |),这样可以报告所有需要的各级别错误。
error_reporting(E_ERROR | E_NOTICE | E_PARSE);//这样是不会显示Warning错误的

//报告 E_NOTICE也挺好 (报告未初始化的变量或者捕获变量名的错误拼写)
//error_reporting(E_NOTICE);

//Warning: main(): It is not safe to rely on the system's timezone settings. You a
//re *required* to use the date.timezone setting or the date_default_timezone_set(
//) function. In case you used any of those methods and you are still getting this
// warning, you most likely misspelled the timezone identifier. We selected the ti
//mezone 'UTC' for now, but please set date.timezone to select your timezone. in E
//:\PhpDemo\error_level.php on line 64

//Notice: Undefined variable: i in E:\PhpDemo\error_level.php on line 64

$j = $i / 2;

//Warning: Division by zero in E:\PhpDemo\error_level.php on line 24

$j = $j / 0;

Debug设置错误级别

define('DEBUG', true); // 在开发时,声明一个DEBUG模式
if (defined('DEBUG')) { //检测到处于开发模式
    error_reporting(E_ALL);  //报告所有错误
} else {
    error_reporting(0);
}

这个php代码18行错误提示

06-02

[img=http://img.bbs.csdn.net/upload/201506/02/1433209798_331901.jpg][/img]rnrnrnrnrn无远程图片"; rnif(preg_match('/(http:\/\/)/i', $row['goods_desc'])) rn $aa="Go Get It"; rn rn echo $row['goods_id']." ".$row['goods_name']." ".$aa." "; rn rn rnexit(); rn rn rn rn rn rn rnsleep(1); rn rn rn$sql="select `goods_desc` from `p_goods` where `goods_id`='$id' limit 1"; rn$res=mysql_fetch_array(mysql_query($sql)); rn rnpreg_match_all('/src=[\'|"]([^"|^\']+)[\'|"]/i', $res[0], $picurl); rn$urlArr=$picurl[1]; rn/* rnprint_r($urlArr); rndie(); rn$urlArr[]="http://static.oschina.net/uploads/user/129/258733_50.jpg"; rn$urlArr[]="http://static.oschina.net/uploads/img/201302/16195715_kPci.png"; rn*/ rn$num= isset($_GET['num']) ? $_GET['num'] : 1; rn rn$all=count($urlArr); rn rn rn$url=$urlArr[$num-1]; rn rn rnif(!preg_match('/(http:\/\/)/i', $url)) rn if($num >= $all) rn exit(' all done!'); rn rn echo $url." 已处理"; rn echo " "; rn exit(); rn rn rn rn rn$array=@get_headers($url,1); rn rnecho $url." "; rn rnif(preg_match('/200/',$array[0])) rn rn ob_start(); rn readfile($url); rn $img = ob_get_contents(); rn ob_end_clean(); rn $dir="images/goods_desc"; rn rn if (!file_exists($dir)) rn rn mkdir($dir, 0777); rn rn rn $filename=$dir."/".mt_rand(11111,9999999999).time().".jpg"; rn $f=fopen($filename,'a'); rn $fres=fwrite($f,$img); rn fclose($f); rn rn if($fres!=false) rn $goods_desc=str_replace($url,"/".$filename,$res[0]); rn $sql="update `p_goods` set `goods_desc` = '$goods_desc' where `goods_id`='$id' limit 1 "; rn mysql_query($sql); rn rn rn rn rnecho $num."/".$all; rn rnif($num >= $all) rn rnexit(' all done!'); rn rnelse rn rnecho " "; rn rn rn rn rn rn?>

没有更多推荐了,返回首页

私密
私密原因:
请选择设置私密原因
  • 广告
  • 抄袭
  • 版权
  • 政治
  • 色情
  • 无意义
  • 其他
其他原因:
120
出错啦
系统繁忙,请稍后再试