首頁  >  文章  >  後端開發  >  PHP檔案載入與錯誤處理的介紹

PHP檔案載入與錯誤處理的介紹

不言
不言原創
2018-07-05 09:38:141642瀏覽

這篇文章主要介紹了關於PHP檔案載入和錯誤處理的介紹,有著一定的參考價值,現在分享給大家,有需要的朋友可以參考一下

知識點:

  1-檔案載入

  2-錯誤處理


 


##檔案載入

  檔案載入語句

#    1) 4個檔案載入語句:

include,  require,   include_once.

##    2) 使用形式相同。

include 「要載入的檔案完整路徑」;

  或 

include(「要載入的檔案

完整

路徑」);  

        如        如"d:/index.php";

    3)  

可以載入的檔案: php 或html檔案

  路徑

    1)

相對路徑

: 相對於目前網頁檔案所在的位置來定位某個已載入的檔案位置      ./   :      ./   :  目前網頁檔案所在的位置(目錄);      ../   :    表示上一級位置,即網頁檔案所在的位置的上一級位置(目錄);    2)#絕對路徑

      本地絕對路徑; 如: include "d:/demo/index.php";      網絡絕對路徑;       網絡絕對路徑;

      網路絕對路徑; .com/demo/index.php"

    3)  不寫路徑,直接檔案名稱

      實質是載入目前目錄下的指定檔案名稱「     實質就是載入目前目錄下的指定檔案名稱「     」如index.php";  //PHP語言引擎會在目前網頁目錄下找該檔案 

#  檔案載入執行過程

step 1: 从include|require 语句处退出PHP脚本模式(进入html代码模式)
step 2:载入include|require 语句所设定的文件中的代码,并执行
step 3:退出html模式重新进入php脚本模式,继续之后的代码

  include,include_once, require,require_once的區別

  1) include 與require 的區別, 或include_once與require_once的區別

ude#in# in布〦思入文件失敗時(即沒有找到該文件),報“

提示錯誤

“,然後

繼續執行後續程式碼

       require 或require_once載入檔案失敗時,報錯誤並

立即終止

#執行。

               一般,並使用在程式中,而後續的程式碼則依賴載入的檔案的時候。

  2) inlcude 與include_once,  或require與require_once的區別

     include 或require載入的檔案

不判斷是否重複

,只要有include或requireinclude會載入一次---即可能重複載入。

       include_once或require_once載入的檔案會有內部判斷機制是否「前面程式碼「已經載入過,###如果載入過,就不再載入###。 ###                如:  中在網頁中常見的相同廣告,就是使用include#########  被載入中 return的使用」 恀拀> include_once,require_once載入語句,如果載入成功回傳1,載入失敗回傳false######    2)  若已載入的檔案中有return, 則在該return後的該檔案內容不被載入--終止載入######      可以用於: 被載入檔案給載入檔案回傳一個資料######錯誤處理##########   錯誤分類#################   錯誤分類######################## ####   1) 語法錯誤######    如果語法有錯誤,就會立即報錯,並且不會去執行程式######  2) 執行時錯誤######     2) 執行時錯誤######                   檢查通過後,開始運行程序,並在此過程中遇到的錯誤######      常見3類錯誤: 提示性錯誤,警告性錯誤,致命錯誤#####  3)邏輯錯誤## ####    程式本身可以正常執行,沒有報錯。但不是想要的結果。 ###

  错误分级

  1) 技术层面的错误分级: PHP语言中,将各种错误进行了不同级别的分类归纳

    每一级别的错误,都有一个“代号”,这个代号是系统内部的一个“常量”

  2)系统常见错误

       E_ERROR:        致命错误
       E_WARNING:    警告性错误
       E_NOTICE:      提示性错误

  3) 用户自定义错误

    E_USER_ERROR:           自定义致命错误
    E_USER_WARNING:    自定义警告性错误
    E_USER_NOTICE:        自定义提示性错误

  4) 其他

    E_STRICT:     严谨性语法检查错误
    E_ALL:           代表所有错误

  详细参考手册: 函数参考》影响PHP行为的扩展》错误处理和日志记录》预定义常量

 1 <?php 
 2 function getBinStr($e) { 
 3     $s = decbin($e);  //这是一个二进制数字字符串 
 4     /* 
 5         str_pad($str1,长度n,$str2,位置w)函数: 
 6             将字符串$str1,用字符串$str2填充到指定的长度n, 
 7             可以指定填充的位置w,左边填充还是右边填充 
 8     */ 
 9     $s1 = str_pad($s,16,"0",STR_PAD_LEFT);
 10     return $s1;
 11 }
 12     echo "<pre class="brush:php;toolbar:false">";
 13     echo "E_EEROR = ".E_ERROR . "\t\t其对应二进制值为: " . getBinStr(E_ERROR);   //1
 14     echo "<br />E_WARNING = ".E_WARNING. "\t\t其对应二进制值为: " . getBinStr(E_WARNING);  //2
 15     echo "<br />E_NOTICE = ".E_NOTICE. "\t\t其对应二进制值为: " . getBinStr(E_NOTICE);   //8
 16     echo "<br />E_USER_NOTICE = ".E_USER_NOTICE. "\t\t其对应二进制值为: " . getBinStr(E_USER_NOTICE);   //1024
 17     echo "<br />E_ALL = ".E_ALL. "\t\t其对应二进制值为: " . getBinStr(E_ALL);   //32767
 18     echo "
"; 19 ?>

查看错误分级对应的二进制数测试

  错误触发

  1) 方式1: 系统触发

    典型错误3种: 

      E_NOTICE:      提示性错误:  会输出错误提示,并继续执行后续代码;如:使用不存在的变量或常量

      E_WARNING:    警告性错误:  会输出错误提示,并继续执行后续代码; 如: include载入一个不存在的文件:

      E_ERROR:        致命错误: 导致程序无法执行后续语句;  如: 一个不存在的函数!!

  2) 方式2: 自定义触发

    1) 概念: 当处理某些数据时,数据本身没有错误,但根据具体应用(业务)的需要,会要求数据满足某种条件,而该数据并不满足的时候,可以在程序中“主动”去触发(创建)一个错误,以表明该数据的“非法性”。

    2) 语法形式: trigger_error(“错误提示信息内容”,3种用户错误代号之一);  

      如果触发了用户的致命错误(E_USER_ERROR),会终止程序的后续执行

  错误报告的显示

  1) 错误报告: 显示在网页上的错误提示内容

  2) 是否显示错误报告 ?  display_errors

    方式1:全局设置

      修改配置文件php.ini 的配置项 display_errors = On; //表示显示 如果是Off表示关闭

    方式2: 局部设置

      在php脚本文件中使用函数ini_set()来对它进行设置; 如 ini_set("display_errors",0); //不显示错误报告

      该方式设置要优先于全局设置

  3) 显示哪些级别的错误报告?  error_reporting

    前提: display_errorrs=On;

    方式1: 全局设置

      修改配置文件php.ini 的配置项error_reporting,   如 : error_reporting = E_NOTICE | E_WARNING | E_ERROR

    方式2: 局部设置

      在php脚本文件中使用函数ini_set()来对它进行设置 , 如init_set(“error_reporting”,E_NOTICE | E_WARNING | E_ERROR),

  错误日志的记录

  1)是否记录错误日志?  log_errors

    方式1: 全局设置

      修改配置文件php.ini 的配置项log_errors,   如 : log_errors= On;  //记录错误日志

    方式2: 局部设置

      在php脚本文件中使用函数ini_set()来对它进行设置 , 如init_set(“log_errors”,1);//记录错误日志

      获取php.ini配置项: ini_get("配置项");  //获取php.ini的指定配置项值

  2)记录到哪里? error_log

    可以指定位置或记录到系统日志中

    指定位置文件中:直接使用文件名,系统会自动在文件夹下都建立该文件名,并用其记录该文件夹下的所有网页文件发生的错误信息

        ini_set("error_log", "myError.txt");   //如果有错误,将记录在myError.txt文件中

    写入系统日志中:  ini_set("error_log", "syslog");//所有错误日志记录到系统 日志文件 中

  自定义错误处理器

  1)错误处理器: 发生错误,用来处理该错误的一种方法。实质就是一个函数

  2) 自定义错误处理器: 将原本有系统处理错误变为开发者自定义对错误显示和记录处理

  3) 分2步:

    step 1:  设定用于处理错误的函数 set_error_handler("函数名");  如 set_error_handler('myError');

    step 2: 声明定义处理错误的函数。 如 function myError($errCode,  $errMsg, $errFile,  $errLine) { //错误处理  }

 1 <?php 
 2 //自定义错误处理器 
 3 //第一步: 设定要作为错误处理的函数名 
 4 set_error_handler("my_error_handler"); 
 5  
 6 //第2步: 定义函数 
 7  /** 
 8   * 自定义错误处理函数 
 9   * 该函数不要在程序中调用,一发生错误会被自动调用,而且会传入该4个实参数据
 10   * @param  string $errCode 错误代号(级别)
 11   * @param  string $errMsg  错误信息的内容
 12   * @param  string $errFile 发生错误的文件名
 13   * @param  int $errLine  代表发生错误的行号
 14   * @return void
 15   */
 16 function my_error_handler($errCode,$errMsg,$errFile,$errLine) {
 17     $str = &#39;&#39;;
 18     $str .= "<p><b><font color=&#39;red&#39;>错误:</font></b>";
 19     $str .= "<br />错误代号是:".$errCode;
 20     $str .= "<br />错误内容是:".$errMsg;
 21     $str .= "<br />错误文件是:".$errFile;
 22     $str .= "<br />错误行号是:".$errLine;
 23     $str .= "<br />发生的时间:".date("Y-m-d H:i:s");
 24     $str .= "</p>";
 25     echo $str;     //输出该“构建”的错误完整处理结果
 26                    //可以将该内容写入到某个文件去,既记录错误日志
 27 }
 28 
 29 //以下是错误代码
 30 echo "<br />aaaa";
 31 echo $v1;   //使用不存在的变量
 32 echo C1;    // 使用不存在的常量
 33 echo "<br />bbbb";
 34 echo "<hr />";

点击查看自定义错误处理器测试

以上就是本文的全部内容,希望对大家的学习有所帮助,更多相关内容请关注PHP中文网!

相关推荐:

PHP基本语法的介绍

PHP的环境搭建 的方法

以上是PHP檔案載入與錯誤處理的介紹的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn