0.6 PHP 文件控制


文件加载
  • 语法形式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 命令所在文件的所在目录;

  • 文件载入原理
  1. 在执行 include 语句的地方截断;
  2. 载入 include 文件中的代码,并编译;
    ▁ 注意:此处的载入并非 "引入文件",实际效果相当于 "引入代码"
  3. 继续执行之后的代码。

无关的文字会被输出

无关的文字会被输出


  • return 关键字
    立即结束函数的执行并将参数作为函数的值返回。
return; // 结束函数或脚本文件
return $x; // 结束并返回

在载入文件中的 return 关键字同样具有相同的作用。




index 文件 code 1

" include 'other.php'; echo "

index 文件 code 2

" ?> code 1 new code 991 code 2


code 1
666
code 2
错误处理
  • 分类分级
  • 错误分类
    1. 语法错误:程序无法运行,直接提示语法错误;
    2. 运行时错误:只有程序运行到某行、或特定条件下的错误;
    3. 逻辑错误:程序到结束都没有提示错误,但是运行结果是错误的;
  • 错误分级
    PHP 将各种错误分门别类,依据错误程度和机制,分为约10几个级别;
    每个级别的错误,都对应一个名称(系统常量),常见的错误如下:
    ◇  E_ERROR:系统错误,一旦发生,程序立即停止;
    ◇  E_WARNING:系统警告,警告错误,但是程序会保持执行;
    ◇  E_PARSE:解析错误,由程序解析器报告;
    ◇  E_NOTICE:系统提示,非关键性的错误提示;
echo "
E_ERROR".E_ERROR; //1 echo "
E_WARNING".E_WARNING; //2 echo "
E_PARSE".E_PARSE; //4 echo "
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 "
code 2"; //正常运行 $fn=func(); //不存在的函数——Fatal error 严重错误 echo "
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设定的规则进行处理,同时生成错误日志文件;

你可能感兴趣的:(0.6 PHP 文件控制)