Apache下開啟SSI配置使html支持include包含的方法
寫頁面的同學(xué)通常會(huì)遇到這樣的煩惱,就是頁面上的 html 標(biāo)簽越來越多的時(shí)候,尋找指定的部分就會(huì)很困難,那么能不能像 javascript 一樣寫在不同的文件中引入呢?答案是有的,apache 能做到。
舉個(gè)簡(jiǎn)單的例子,比如有如下的 html 文件(命名為 index.html):
<input type='text' /> <input type='button' value='press' />
一個(gè)簡(jiǎn)單的文本框和按鈕,我現(xiàn)在想把按鈕部分的 html 寫在另一個(gè) .html 的文件中(比如說叫 btn.html)然后引入到 index.html 中,要怎么做呢?
1、加載 ssi 模塊
首先要加載 ssi 模塊。打開 apache 的配置文件 httpd.conf,這個(gè)文件應(yīng)該都已經(jīng)很熟悉了,前面的文章中多次提到。找到這么一行 LoadModule ssl_module modules/mod_ssl.so,把前面的注釋(#)去掉。
2016.01.11 更:
經(jīng)本地測(cè)試,此步驟并不是必須的,多謝 whuper 指出。
2、添加需要的文件類型
同樣在 httpd.conf 文件下找到如下兩行代碼:
AddType text/html .shtml AddOutputFilter INCLUDES .shtml
有注釋的話一樣去掉注釋。因?yàn)槭褂?ssi 技術(shù)的默認(rèn)文件名為 .shtml,所以我們需要在配置文件中對(duì) .shtml 后綴名進(jìn)行設(shè)置,并按自己的需求設(shè)置需要對(duì) ssi 技術(shù)進(jìn)行解析的文件類型設(shè)置。
比如這里我要用 .html 的文件進(jìn)行操作,所以可以在上面兩行代碼末添加,比如這樣:
AddType text/html .shtml .html AddOutputFilter INCLUDES .shtml .html
3、添加 INCLUDES
還是在 httpd.conf 文件中,找到這樣一行 Options Indexes FollowSymLinks
,在后面添加 INCLUDES,變成這樣:
Options Indexes FollowSymLinks INCLUDES
需要注意的是,ssi 可以利用 shell 來執(zhí)行命令,因此這個(gè)功能是有危險(xiǎn)的,它會(huì)執(zhí)行任何包含在 exec 標(biāo)記中的命令,如果你的用戶有權(quán)限修改你的網(wǎng)頁內(nèi)容,建議把該功能關(guān)閉。當(dāng)然你還可以加上IncludesNOEXEC 參數(shù),來關(guān)閉 exec 功能,同時(shí)又保留 SSI 。此時(shí)改為: Options Indexes FollowSymLinks INCLUDES IncludesNOEXEC
4、重啟 apache
最后一點(diǎn),重啟 apache 千萬不能忘記,有些童鞋剛開始配置 apache 的時(shí)候,經(jīng)常會(huì)說怎么不起作用啊,很多時(shí)候就是忘記重啟了。
5、實(shí)踐
通過這樣的配置我們就能在 html 頁面中引入 html 文件了,比如這樣:
<input type='text' /> <!--#include virtual="btn.html" -->
也可以用 file
參數(shù):
<input type='text' /> <!--#include file="btn.html"-->
有什么區(qū)別呢...
include 元素能按 file 屬性或 virtual 屬性判斷應(yīng)該包含的文件。file 屬性是一個(gè)相對(duì)于當(dāng)前目錄的文件路徑,即不能是一個(gè)絕對(duì)路徑(以 "/" 開頭)或包含 "../" 的路徑,也就是說被包含文件可以在同一級(jí)目錄或其子目錄中,但不能在上一級(jí)目錄中。virtual 屬性可能更有用,它是一個(gè)相對(duì)于被提供的文檔的URL ,可以以 "/" 開頭,但必須與被提供的文檔位于同一服務(wù)器上,virtual 文件名是 Web 站點(diǎn)上的虛擬目錄的完整路徑。
通俗地說,virtual 相當(dāng)于絕對(duì)路徑(從服務(wù)器根目錄出發(fā)),而 file 相當(dāng)于相對(duì)路徑(而且文件還不能在上級(jí)目錄)。所以一般用 virtual 就 ok 了。
參考:
相關(guān)文章
Linux初學(xué)(CnetOS7 Linux)之切換命令模式和圖形模式的方法
本篇文章主要介紹了Linux初學(xué)(CnetOS Linux7)之切換命令模式和圖形模式的方法,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2018-03-03在CentOS 6 中安裝 WordPress(二)安裝WordPress
上篇文章我們介紹了WordPress環(huán)境的配置,本文我們就來詳細(xì)講解下WordPress的安裝,適合新手,高手們請(qǐng)勿拍磚2014-06-06Linux系統(tǒng)禁止root賬號(hào)遠(yuǎn)程登錄的命令
這篇文章主要介紹了Linux系統(tǒng)禁止root賬號(hào)遠(yuǎn)程登錄的方法,文中給大家提到linux下禁止root遠(yuǎn)程登錄和添加新用戶,需要的朋友可以參考下2019-07-07CentOS7 修改網(wǎng)卡名稱為eth0&在VMWare中添加多網(wǎng)卡配置
這篇文章主要介紹了CentOS7 修改網(wǎng)卡名稱為eth0&在VMWare中添加多網(wǎng)卡配置,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下。2017-03-03crontab定時(shí)任務(wù)不執(zhí)行的一些原因總結(jié)
這篇文章主要給大家總結(jié)介紹了關(guān)于crontab定時(shí)任務(wù)不執(zhí)行的一些原因,對(duì)每種可能發(fā)生的原因都給出了解決方法,對(duì)遇到這個(gè)問題的朋友們具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2019-01-01