错误处理:
1. 语法错误
2. 运行时的错误
3. 逻辑错误
错误报告:
错误E_ERROR
警告E_WARNING
注意E_NOTICE
开发阶段:开发时输出所有的错误报告,有利于我们进行调试
运行阶段:不要让程序输出任何一种错误报告
将错误报告写入日志中
一. 指定错误报告error_reporting=E_ALL(在php.inn)
二. 关闭错误输出display_errors=off(在php.ini中)
三. 开启错误日志的功能log_errors=on(在php.ini中)
1. 默认如果不指定错误日志位置,则默认写入web服务器的日志中
2. 为error_log选项指定一个文件名,这个文件名就是错误日志
3. 写入到操作系统日志中error_log=syslog
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
|
<?php
//注意和警告都不会终止程序的运行,但是错误会终止程序的运行
/*
错误E_ERROR
警告E_WARNING
注意E_NOTICE
*/
//所有的错误都输出除了注意
error_reporting (E_ALL & ~E_NOTICE);
//设置配置文件的值(临时)
//ini_set("upload_max_filesize", 2000000000);
//得到配置文件的值
//ini_get("upload_max_filesize");
//关闭错误报告的显示,一般在运行阶段使用
ini_set ( "display_errors" , "off" );
//将错误报告写入日志中
ini_set ( "log_errors" , "on" );
//日志的目录
ini_set ( "error_log" , "D:/error.log" );
gettype ( $var ); //注意
gettype (); //警告
//getype(); //错误,程序终止
echo "############<br>" ;
?>
|
异常处理:意外,是在程序运行过程中发生的意料之外的事,使用异常改变脚本正常流程
PHP5中的一个新的重要特性
try{
}catch(异常对象){
}
1. 如果try中代码没有问题,则将try中代码执行完成后就到catch后执行
2. 如果try中代码有异常发生,则抛出一个异常对象(使用throw),抛出给了catch中的参数,则在try中出现异常代码后的内容就不会执行,直接跳转到catch中去执行,catch中执行完成,再继续向下执行
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
|
<?php
try {
echo "11111111<br>" ;
$file =@ fopen ( "./hello.txt" , "r" );
if (! $file ){
throw new Exception( "文件打开失败" );
}
echo "2222222222<br>" ;
} catch (Exception $e ){
echo "3333333<br>" ;
echo $e ->getMessage(). "<br>" ;
touch( "hello.txt" );
$file =@ fopen ( "./hello.txt" , "r" );
}
echo "4444444<br>" ;
?>
|
以上这篇浅谈PHP中的错误处理和异常处理就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持服务器之家。