本文旨在提供如何用apache重寫規則來解決一些常見的url重寫方法的問題,通過常見的實例給用戶一些使用重寫規則的基本方法和線索。
一、為什么需要用重寫規則
網站的生命在于不斷地進行更新和維護,根據業務發展的需求轉移服務器進行維護、重新組織目錄結構、變換url甚至改變到新的域名等情況是經常發生的。為了讓客戶不會因此受到任何影響,最好的方法就是使用apache rewrite rule(重寫規則)。
二、重寫規則的作用范圍
1.使用在apache主配置文件httpd.conf中。
2.使用在httpd.conf里定義的虛擬主機配置中。
3.使用在基本目錄的跨越配置文件.htaccess中。
三、重寫規則的應用條件
當用戶的web請求最終被導向到某臺web服務器的apache守護進程,apache根據配置文件判斷該請求是主配置還是虛擬主機,再根據用戶在瀏覽器中請求的url來匹配重寫規則,并且根據實際的請求路徑匹配.htaccess中的重寫規則,最后把請求的內容傳回給用戶。該響應可能有2種。
1.將請求內容外部重定向(redirect)到另一個url
讓瀏覽器再次以新的url發出請求(r=301或者r=302,臨時的或是永久的重定向)。
例如,一個網站有正規的url和別名url,對別名url進行重定向到正規url,或者網站改換成了新的域名,則把舊的域名重定向到新的域名。
2.由apache內部子請求代理產生新的內容送回給客戶[p,l]
這是apache內部根據重寫后的url,通過代理模塊請求內容并將最終內容送回給客戶,客戶端瀏覽器不必再次請求,瀏覽器中的url不會被重寫,但實際內容由apache根據重寫規則后的url生成。
例如,在公司防火墻上運行的apache啟動這種代理重寫規則,代理對內部網段上的web服務器的請求。
四、重寫規則怎樣工作
我們假定在編譯apache時已經把mod_rewrite編譯成模塊,確信您的httpd.conf中有loadmodule rewrite_module libexec/mod_rewrite.so,并且在addmodule中有addmodule mod_rewrite.c,則可以使用重寫規則。
當外部請求到達apache,apache調用重寫規則中的定義來重寫由用戶瀏覽器指定請求的url,最后被重寫的url如果是重定向,則送交瀏覽器做再一次請求;如果是代理則把重寫后的url交給代理模塊請求最終的內容(content),最后把內容送回給瀏覽器。
五、何時使用.htaccess中的重寫規則定義
假如您對網站內容所在的服務器沒有管理員權限,或者您的網站內容放在isp的服務器上托管,無法改寫主配置文件,但是您對web站點內容所在的目錄有寫權限,則可以設置自己的.htaccess文件達到同樣的目的。但您需要確定主配置文件中對您的網站所在的目錄定義了下面的內容,否則您的.htaccess不會工作。
|
六、應用舉例
假定apache被編譯安裝在主機192.168.1.56的/usr/local/apache目錄下面,同時編譯了重寫和代理模塊。
1.隱藏apache下的某個目錄,使得對該目錄的任何請求都重定向到另一個文件
(1)httpd.conf的實現方法
我們將下面的部分放到/usr/local/apache/conf/httpd.conf中。
|
注: “rewriteengine on”為重寫引擎開關,如果設為“off”,則任何重寫規則定義將不被應用,該開關的另一用處就是如果為了臨時去掉重寫規則,可以將引擎開關設為“off”再重新啟動apache即可,不必將其中的各條重寫規則注釋掉。
“rewritebase /”的作用是如果在下面的rewriterule定義中被重寫后的部分(此處為文件名index.html.en)前面沒有“/”,則表明是相對目錄,相對于這個rewritebase后面的定義也就是/usr/local/apache/htdocs/index.html.en,否則,如果此處沒有“rewritebase /”這一項,則被重寫成http://192.168.1.56/usr/local/apache/htdocs/manual/index.html.en,顯然是不正確的。
我們也可以不用“rewritebase /”,而是將其改為如下部分。
|
或者更改為:
|
(2).htaccess的實現方法
我們將下面的部分放到httpd.conf中。
|
然后將下面的部分放到/usr/local/apache/htdocs/manual/.htaccess中。
|
注: 對文件.htaccess所做的任何改動不需要重啟動apache。
您還可以利用.htaccess方案將這個manual目錄重定向到用戶jephe自己的主目錄。
|
這樣,對manual目錄下任何文件的請求被重定向到~jephe目錄下相同文件的請求。
2.將http://www.username.domain.com對于username的主頁請求轉換為對http://www.domain.com/username的請求
對于http/1.1的請求包括一個host: http頭,我們能用下面的規則集重寫
|
注: “rewritecond”表明是條件重寫規則,當滿足后面定義的條件后才會應用下面的重寫規則,“rewritecond”有各種變量,請查閱相關文檔。
3.防火墻上的重寫規則代理內部網段上服務器的請求
|
注: 當外部瀏覽器請求http://www.domain.com時,將被解析到ip地址1.2.3.4,apache交由mod_rewrite處理,轉換成http://192.168.1.3/$1后再交由代理模塊mod_proxy,得到內容后傳送回用戶的瀏覽器。
4.基本預先設定的轉換map表進行重寫rewritemap
轉換http://www.domain.com/{countrycode}/anypath到map表中規定的url,前面是虛擬主機中的定義。
|
文件/usr/local/apache/conf/rewrite.map的內容如下:
|
注: 當用戶請求http://www.domain.com/sg/anypath時被重寫為http://a.b.c.d/anypath。當需要調試時請用rewritelog和 rewriteloglevel 9聯合,9為最大,即得到最多的調試信息;最小為1,表示得到最少的調試信息;默認為0,表示沒有調試信息。
sitemap的語法是${sitemap: lookupkey | defaultvalue},有些書上把$寫成了%是錯誤的。
新聞熱點
疑難解答