文件加载
-
语法形式:
include、include_once、require、require_once
4 种语法都用于 "加载 / 引入 / 包含" 一个外部文件: -
include
:加载失败会发出警告,但会继续执行代码。
▁例如植入的外链广告等,对原页面不影响。
-
require
:加载失败会立即终止。
▁例如连接数据库等对页面有要求的文件。
-
???_once
能够保证不会被重复加载。
// 都属于语法结构,() 不是必须使用:
include '文件路径'; // 正确
include('文件路径'); // 正确
- 文件路径
- 相对路径:
./
代表当前文件夹;
../
代表上级文件夹; - 绝对路径:
▁ 本地绝对路径:
windows 系统:c:/php/index.php
unix 系统:/php/index.php
▁ 网络绝对路径:http://www.abc.com/php/index.php
- 文件名(无路径)
include、require...
等语法中,在没有明确路径的情况,文件的查找规则:
1. 在系统设置的include
目录中查找;
php.ini
中可以配置include
的路径:include_path
;
include_path=". ; c:/php/includes; c:/somedir/project;";
在 PHP 代码中设置:
/*
*仅对当前 php 代码生效
*/
set_include_path('c:/somedir/project');
//常用做法,多人协作更加友好
$path=get_include_path();
$path_new=$path.PATH_SEPARATOR.";c:/somedir/project";
set_include_path($path_new);
PATH_SEPARATOR
为系统常量,代表目录分隔符。
2. 第 1 步没找到的情况下,转向当前网页文件所在目录查找;
3. 第 2 步没找到的情况下,转向当前 include
命令所在文件的所在目录;
- 文件载入原理
- 在执行
include
语句的地方截断; - 载入
include
文件中的代码,并编译;
▁ 注意:此处的载入并非"引入文件"
,实际效果相当于"引入代码"
。 - 继续执行之后的代码。
<!--other.php 文件内容-->
无关的文字会被输出
<?php
echo 'other.php 的代码';
$includeNum++;
$otherNum=998;
?>
无关的文字会被输出
<!--主文件的内容-->
<?php
echo "code1";
$includeNum=10;
//实际效果中这里:无关的文字...
include './other.php';
//实际效果中这里:无关的文字...
echo "code2";
echo $includeNum; // 11
echo $otherNum; // 998
?>
-
return 关键字
立即结束函数的执行并将参数作为函数的值返回。
return; // 结束函数或脚本文件
return $x; // 结束并返回
在载入文件中的 return 关键字同样具有相同的作用。
<!--载入文件内容-->
<?php
echo 'new code 991';
return;
echo 'new code 992';
?>
<!--index.php-->
<?php
echo "<p>index 文件 code 1</p>"
include 'other.php';
echo "<p>index 文件 code 2</p>"
?>
<!--输出结果-->
code 1
new code 991
code 2
<!--返回值文件内容-->
<?php
echo 'new code 991';
return;
echo 'new code 992';
?>
code 1
666
code 2
错误处理
- 分类分级
- 错误分类
1. 语法错误:程序无法运行,直接提示语法错误;
2. 运行时错误:只有程序运行到某行、或特定条件下的错误;
3. 逻辑错误:程序到结束都没有提示错误,但是运行结果是错误的; - 错误分级
PHP 将各种错误分门别类,依据错误程度和机制,分为约10几个级别;
每个级别的错误,都对应一个名称(系统常量),常见的错误如下:
◇ E_ERROR:系统错误,一旦发生,程序立即停止;
◇ E_WARNING:系统警告,警告错误,但是程序会保持执行;
◇ E_PARSE:解析错误,由程序解析器报告;
◇ E_NOTICE:系统提示,非关键性的错误提示;
echo "<br/>E_ERROR".E_ERROR; //1
echo "<br/>E_WARNING".E_WARNING; //2
echo "<br/>E_PARSE".E_PARSE; //4
echo "<br/>E_NOTICE".E_NOTICE; //8
- 自定义错误
◇ E_USER_ERROR
◇ E_USER_WARNING
◇ E_USER_NOTICE
在程序中,我们可以针对逻辑问题,自定义创建错误(比如年龄不能填写188) - 其他
◇ E_ALL:"包含" 所有错误;
◇ E_STRICT:"严格性" 语法检查错误; - 错误触发
- 正常情况,3种常见的运行时错误:
echo $v998; //不存在的变量——Notice 提示错误
echo "code 1"; //正常运行
include 'file.php'; //不存在的文件——Warning 警告错误
echo "<br/>code 2"; //正常运行
$fn=func(); //不存在的函数——Fatal error 严重错误
echo "<br/>code 3"; //程序终止,code 未输出
- 手动触发
指自定义设置的错误,语法形式:
trigger_error('E_USER_ERROR',);
trigger_error('E_USER_WARNING',);
trigger_error('E_USER_NOTICE',);
$age=1998;
if($age>0&&<120){
echo "年龄在常理范围内";
}else{
trigger_error('我靠,妖怪啊',E_USER_WARNING);
}
- 错误显示
- 是否显示详细错误:
1. php.ini 中设置:display_error=On; //默认,Off 为隐藏
2. php代码中设置:ini_set('display_errors',true); //默认,false 为隐藏
- 是否显示级别错误:
1. php.ini 中设置:
//只显示 E_NOTICE 错误
error_reporting=E_NOTICE;
//只显示 E_NOTICE 错误
error_reporting=E_NOTICE|E_WARNING;
//只显示 E_NOTICE 错误
error_reporting=E_NOTICE|E_WARNING|E_ERROR;
2. php代码中设置:
error_reporting=E_ALL|E_STRICT;
//E_ALL 30719 在计算机二进制中为 111011111111111 几乎包含了所有的错误
//E_STRICT 2048 在计算机二进制中为 000100000000000
//或运算的结果为 error_reporting=111111111111111 所有可能发生的错误
- 在只需关闭个别错误时:
1. php.ini 中设置:
//位运算
error_reporting=E_ALL|E_STRICT & ~E_NOTICE; //只关闭 E_NOTICE
error_reporting=E_ALL|E_STRICT & ~E_NOTICE & ~E_WARNING;
//关闭 E_NOTICE 和 E_WARNING
2. php代码中设置:
ini_set("error_reporting",E_NOTICE); //只显示 E_NOTICE
ini_set("error_reporting",E_ALL|E_STRICT & ~E_NOTICE); //关闭 E_NOTICE
ini_set()
几乎可以设定所有 php.ini
中的配置项:int_set('配置项',值)
◇ 这种设定只对当前脚本有效(无冲突)
,而且无需重启 apache(快速)
。
◇ 在多个网页协作的时候,做一个配置项就可以方便其他网页引入(方便)
。
◇ 在没有办法修改 php.ini
时,非常合适使用 ini_set()
:
——在公司的权值不够;
——使用的商业服务器;
- 错误日志
- 应用规则:
◇ 开发阶段,通常显示所有错误,方便进行调试;
◇ 产品阶段,通常隐藏所有错误,将错误信息记录在文件中,然后通过错误日志文件对产品的问题进行调试解决。 - 记录日志:
1. 在php.ini
文件中设定:
log_errors = On;
错误日志设定,默认开启,Off 关闭;
error_log="文件名"
错误日志文件名的设置;
▁ 如果没有指定文件路径,系统则会在每个文件夹下建立日志文件。
▁ error 还有一个特殊值可以使用:
//不会记录错误文件,而是将错误文件写入系统信息中去
error_log=syslog
2. 在 PHP 脚本文件中:
ini_set("log_errors",On); //开启、关闭错误日志
ini_set("error_log",syslog) //系统日志关键字
//日志文件名设置及文件类型
ini_set("error_log",err.log);
ini_set("error_log",err.txt);
ini_set("error_log",err.html);
-
自定义错误处理
可以控制错误的提示内容。 - 设定错误由自定义函数处理:
set_error_handler("myFunciton");
function myFunction(){
echo "孩子是隔壁老王的";
}
- 该函数带4个参数:
function errorHandler($errNo,$errMsg,$errFile,$errLine){...}
function myFunction($errNo,$errMsg,$errFile,$errLine){
echo "!!!文件—$errFile— 的第($errLine)行发生错误。";
echo "!!!错误号为($errNo),错误信息为($errMsg)。";
}
/*no 错误号
*msg 错误信息
*file 错误所在文件名
*line 错误所在行
*/
- 注意事项:
1. 参数省略,但是不推荐;
2. 参数名可以变更,但是顺序不能变更;
3. 处理函数无需手动触发,系统会自动调用;
4. 自定义错误处理还需要配合后续的文件操作知识完成日志的生成;
▁ 非严重错误时,程序调用定义处理,并且不会生成日志文件;
▁ 严重错误时,不会调用定义的函数,程序会立即终止,并按照php.ini
设定的规则进行处理,同时生成错误日志文件;