服務(wù)器端包含 (SSI) 用于創(chuàng)建可在多個(gè)頁(yè)面重復(fù)使用的函數(shù)、頁(yè)眉、頁(yè)腳或元素。
include (或 require)語(yǔ)句會(huì)獲取指定文件中存在的所有文本/代碼/標(biāo)記,并復(fù)制到使用 include 語(yǔ)句的文件中。
包含文件很有用,如果您需要在網(wǎng)站的多張頁(yè)面上引用相同的 PHP、HTML 或文本的話。
PHP include 和 require 語(yǔ)句
通過(guò) include 或 require 語(yǔ)句,可以將 PHP 文件的內(nèi)容插入另一個(gè) PHP 文件(在服務(wù)器執(zhí)行它之前)。
include 和 require 語(yǔ)句是相同的,除了錯(cuò)誤處理方面:
- require 會(huì)生成致命錯(cuò)誤(E_COMPILE_ERROR)并停止腳本
- include 只生成警告(E_WARNING),并且腳本會(huì)繼續(xù)
因此,如果您希望繼續(xù)執(zhí)行,并向用戶輸出結(jié)果,即使包含文件已丟失,那么請(qǐng)使用 include。否則,在框架、CMS 或者復(fù)雜的 PHP 應(yīng)用程序編程中,請(qǐng)始終使用 require 向執(zhí)行流引用關(guān)鍵文件。這有助于提高應(yīng)用程序的安全性和完整性,在某個(gè)關(guān)鍵文件意外丟失的情況下。
包含文件省去了大量的工作。這意味著您可以為所有頁(yè)面創(chuàng)建標(biāo)準(zhǔn)頁(yè)頭、頁(yè)腳或者菜單文件。然后,在頁(yè)頭需要更新時(shí),您只需更新這個(gè)頁(yè)頭包含文件即可。
語(yǔ)法
或
PHP include 實(shí)例
例子 1
假設(shè)我們有一個(gè)名為 "footer.php" 的標(biāo)準(zhǔn)的頁(yè)腳文件,就像這樣:
?php
echo "p>Copyright © 2006-" . date("Y") . " W3School.com.cn/p>";
?>
如需在一張頁(yè)面中引用這個(gè)頁(yè)腳文件,請(qǐng)使用 include 語(yǔ)句:
html>
body>
h1>歡迎訪問(wèn)我們的首頁(yè)!/h1>
p>一段文本。/p>
p>一段文本。/p>
?php include 'footer.php';?>
/body>
/html>
例子 2
假設(shè)我們有一個(gè)名為 "menu.php" 的標(biāo)準(zhǔn)菜單文件:
?php
echo 'a href="/index.asp" rel="external nofollow" >首頁(yè)/a> -
a href="/html/index.asp" rel="external nofollow" >HTML 教程/a> -
a href="/css/index.asp" rel="external nofollow" >CSS 教程/a> -
a href="/js/index.asp" rel="external nofollow" >JavaScript 教程/a> -
a href="/php/index.asp" rel="external nofollow" >PHP 教程/a>';
?>
網(wǎng)站中的所有頁(yè)面均使用此菜單文件。具體的做法是(我們使用了一個(gè) div> 元素,這樣今后就可以輕松地通過(guò) CSS 設(shè)置樣式):
html>
body>
div class="menu">
?php include 'menu.php';?>
/div>
h1>歡迎訪問(wèn)我的首頁(yè)!/h1>
p>Some text./p>
p>Some more text./p>
/body>
/html>
例子 3
假設(shè)我們有一個(gè)名為 "vars.php" 的文件,其中定義了一些變量:
?php
$color='銀色的';
$car='奔馳轎車';
?>
然后,如果我們引用這個(gè) "vars.php" 文件,就可以在調(diào)用文件中使用這些變量:
html>
body>
h1>歡迎訪問(wèn)我的首頁(yè)!/h1>
?php
include 'vars.php';
echo "我有一輛" . $color . $car "。";
?>
/body>
/html>
您可能感興趣的文章:- php常見(jiàn)的網(wǎng)絡(luò)攻擊及防御方法
- 全世界最小的php網(wǎng)頁(yè)木馬一枚 附PHP木馬的防范方法
- PHP include任意文件或URL介紹
- 淺談PHP安全防護(hù)之Web攻擊
- php安全攻防世界unserialize函數(shù)反序列化示例詳解