• PHP包含文件函数include、include_once、require、require_once区别总结


    一、使用语法和简介
    
    1、include() 
    语法:include(/path/to/filename)
    include()语句将在其被调用的位置处包含一个文件。包含一个文件与在该语句所在位置复制制定文件的数据具有相同内容的效果。
    使用include()时可以忽略括号。
    
    可以根据条件来执行include()语句。在条件语句中使用include()有个怪现象,它必须包围在语句块大括号中,或者用其他语句包围符括起来。
    
    2、include_once() 
    语法:include_once(filename)
    
    include_once() 语句在脚本执行期间包含并运行指定文件。此行为和 include() 语句类似,唯一区别是include_once()会先判断一下这个文件在之前是否已经被包含过,
    如已经包含,则忽略本次包含。
    include_once() 应该用于嵌套包含的情况下,想确保它只被包含一次以避免函数重定义,变量重新赋值等问题。 小结:include_once()函数的作用与include相同,不过它会首先验证是否已经包含了该文件。如果已经包含,则不再执行include_once。否则,则必须包含该文件。
    除了这一点与include完全相同。
    3、require() 语法:require(filename) require()在很大程度上与include相同,都是将一个模板文件包含到require调用坐在的位置。 require和include之间有两点重要的区别。首先,无论require的位置如何,制定文件都将包含到出现require的脚本中。
    例如,即使require放在计算结果为假的if语句中,依然会包含指定文件。 第二个重要的区别是:require出错时,脚本将停止运行,而在使用include的情况下,脚本将继续执行。
    4、require_once() 语法:require_once(filename) require_once() 语句在脚本执行期间包含并运行指定文件。此行为和 require() 语句类似,
    唯一区别是require_once()会先判断一下这个文件在之前是否已经被包含过,如已经包含,则忽略本次包含。
    require_once() 应该用于嵌套包含的情况下,想确保它只被包含一次以避免函数重定义,变量重新赋值等问题。 小结:随着网站越来越大,可能会出现重复包含某些文件。这也许不是问题,但又是修改了所包含文件的变量后,
    却由于后面再次包含原来的文件而被覆盖,可能不希望出现这种情况。还可能出现另一个问题,即所包含文件中函数名的冲突。使用require_once就可以解决这些问题。 require_once函数确保文件只包含一次。在遇到require_once后,后面再试图包含相同的文件时将被忽略。 二、区别总结
    1、include()与require()语句区别。 两者区别:这两种结构除了在如何处理失败之外完全一样。 include() 产生一个警告,脚本会继续运行。 require() 则导致一个致命错误,脚本会停止运行。 换句话说,如果想在遇到丢失文件或遇到错误时停止处理页面就用 require()。如果想在遇到错误时继续处理页面就用 include()。 注意在 PHP 4.3.5 之前,包含文件中的语法错误不会导致程序停止,但从此版本之后会。 2、include_once()、require_once()与include()、require()的区别 include_once()和require_once()一样,应该用于在脚本执行期间同一个文件有可能被包含超过一次的情况下,
    想确保它只被包含一次以避免函数重定义,变量重新赋值等问题。这就是include_once()和require_once()与include() 和require()的主要区别。 三、需要注意的问题
    1.路径问题 特别是嵌套包含的时候,一定得注意包含文件的路径。 比如 A文件包含了B文件,B文件包含了C文件,A,B,C文件都不在同一个文件夹下,这个时候往往很容易出错误。 解决方案:可以使用 dirname(__FILE__) 语句,这句的意思是获得当前脚本的绝对路径。如:require_once(dirname(__FILE__).'/config.php'); 2.效率问题 include_once(),require_once(),与include(),require()比较,效率要低一些,因为他们至少得先判断一下这个文件是否已包含。
    这一问题在PHP5版本有很大改进,不过效率还是有差别。
  • 相关阅读:
    ubuntu上virsh+kvm安装虚拟机
    Less(31)GET-BLIND-IMPIDENCED MISMATCH-Having a WAF in front of web application
    Less(26a)GET
    Less(26)Trick with comments and space (过滤了注释和空格的注入)
    Less(30)Get-Blind Havaing with WAF
    Less(29)基于WAF的一个错误
    Less(25a)Trick with OR & AND Blind (过滤了or和and的盲注)
    Less(25)Trick with OR & AND (过滤了or和and)
    Less(24)Second Degree Injections *Real treat* -Store Injections (二次注入)
    Less(23)GET
  • 原文地址:https://www.cnblogs.com/wuheng1991/p/5190715.html
Copyright © 2020-2023  润新知