Apache URLRewrite 原理及配置实现
? ? ? ?看一下網站上的一些?URL。您是否發現一些類似于?http://yoursite.com/info/dispEmployeeInfo. ... 99&type=summary?的?URL?或者,您可能將一系列網頁從一個目錄或網站移動到另一個目錄或網站,結果導致已將舊?URL?用作書簽的訪問者斷開鏈接。在本文中,我們將了解如何通過將?http://yoursite.com/info/dispEmployeeInfo. ... 99&type=summary?替換為類似于?http://yoursite.com/people/sales/chuck.smith?的網址,使用?URL?重寫將那些冗長的?URL?縮寫為富有意義且容易記憶的?URL。我們還將了解如何將?URL?重寫用于創建智能?404?錯誤。
? ? ? ? URL?重寫是截取傳入?Web?請求并自動將請求重定向到其他資源的過程。執行?URL?重寫時,通常會檢查被請求的?URL,并基于?URL?的值將請求重定向到其他?URL。例如,在進行網站重組而將?/people/?目錄下的所有網頁移動到?/info/employees/?目錄中時,您可能希望使用?URL?重寫來檢查?Web?請求是否指向了?/people/?目錄中的文件。如果請求指向?/people/?目錄中的文件,您可能希望自動將請求重定向到?/info/employees/?目錄中的同一文件。
URLRewrite原理
mod_rewrite是Apache的一個非常強大的功能,它可以實現偽靜態頁面。下面我詳細說說它的使用方法!對初學者很有用的哦!
1.檢測Apache是否支持mod_rewrite
通過php提供的phpinfo()函數查看環境配置,通過Ctrl+F查找到“Loaded Modules”,其中列出了所有apache2handler已經開啟的模塊,如果里面包括“mod_rewrite”,則已經支持,不再需要繼續設置。
如果沒有開啟“mod_rewrite”,則打開目錄 您的apache安裝目錄“/apache/conf/” 下的 httpd.conf 文件,通過Ctrl+F查找到“LoadModule rewrite_module”,將前面的”#”號刪除即可。
如果沒有查找到,則到“LoadModule” 區域,在最后一行加入“LoadModule rewrite_module modules/mod_rewrite.so”(必選獨占一行),然后重啟apache服務器即可。
2.讓apache服務器支持.htaccess
如 何讓自己的本地APACHE服務器支持”.htaccess”呢?其實只要簡單修改一下apache的httpd.conf設置就可以讓 APACHE支 持.htaccess了。打開httpd.conf文件(在那里? APACHE目錄的CONF目錄里面),用文本編輯器打開后,查找
Options FollowSymLinks
AllowOverride?None
改為
Options FollowSymLinks
AllowOverride?All
就可以了。
3.建立.htaccess 文件
如 果是在windows平臺下,剛開始還真不知道怎么建立”.htaccess”文件,因為這個文件實際上沒有文件名,僅僅只有擴展名,通過普通方 式是無法建立這個文件的,別著急,馬上告訴你三種方法:三種方法都是先建立一個htaccess.txt的文本文件(當然,這個文本文件的名字你可以隨便 取),然后有三種方式給這個文件重命名:
(1)用記事本 打開,點擊文件–另存為,在文件名窗口輸入”.htaccess”,注意是整個綠色部分,也就是包含英文引號,然后點擊保存就行了。
(2)進入cmd命令 窗口,通過cd切換當剛建立htaccess.txt文件的文件夾,然后輸入命令:rename htaccess.txt .htaccess ,然后點擊鍵盤Enter鍵即可。
(3)通過ftp連接htaccess.txt所在文件夾,通過ftp軟件重命名。
4.rewrite規則學習
我們新建一個.htaccess文件之后,就在里面寫入以下內容:
RewriteEngine on?#rewriteengine為重寫引擎開關on為開啟off為關閉
RewriteRule ([0-9]{1,})$ index.php?id=$1
我講解一下RewriteRule:RewriteRule是重寫規則,支持正則表達式的,上面的([0-9]{1,})是指由數字組成的,$是結束標志,說明是以數字結束!
好吧,現在我們可以實現偽靜態頁面了,寫下一下的規則:
<IfModule mod_rewrite.c>
RewriteEngine on
RewriteRule?([a-zA-Z]{1,})-([0-9]{1,}).html$?index.php?action=$1&id=$2
</IfModule>?
([a-zA-Z]{1,})-([0-9]{1,}).html$是規則,index.php?action=$1&id=$2是要替換的格式,$1代表第一個括號匹配的值,$2代表第二個,如此類推!!
我們寫一個處理的PHP腳本:
index.php
PHP代碼 <?php?echo ‘你的Action是:’ . $_GET['action'];?
echo ‘<br/>’;?
echo ‘你的ID是:’ . $_GET['id'];?
?>
好了,我們現在在瀏覽器中輸入:
localhost/view-12.html
輸出的是:
你的Action是:view
你的ID是:12
===================一道華麗的分割線================
13 個mod_rewrite 應用舉例
1.給子域名加www標記?
RewriteCond %{HTTP_HOST} ^([a-z.]+)?example\.com$ [NC]?
RewriteCond %{HTTP_HOST} !^www\. [NC]?
RewriteRule .? http://www.%1example.com%{REQUEST_URI} [R=301,L]?
這個規則抓取二級域名的%1變量,如果不是以www開始,那么就加www,以前的域名以及{REQUEST_URI}會跟在其后。
2.去掉域名中的www標記?
RewriteCond %{HTTP_HOST} !^example\.com$ [NC]?
RewriteRule .??http://example.com%{REQUEST_URI} [R=301,L]?
3.去掉www標記,但是保存子域名?
RewriteCond %{HTTP_HOST} ^www\.(([a-z0-9_]+\.)?example\.com)$ [NC]?
RewriteRule .? http://%1%{REQUEST_URI} [R=301,L]?
這里,當匹配到1%變量以后,子域名才會在%2(內部原子)中抓取到,而我們需要的正是這個%1變量。?
4.防止圖片盜鏈?
一些站長不擇手段的將你的圖片盜鏈在他們網站上,耗費你的帶寬。你可以加一下代碼阻止這種行為。?
RewriteCond %{HTTP_REFERER} !^$?
RewriteCond %{HTTP_REFERER} !^http://(www\.)?example\.com/ [NC]?
RewriteRule \.(gif|jpg|png)$ - [F]?
如果{HTTP_REFERER}值不為空,或者不是來自你自己的域名,這個規則用[F]FLAG阻止以gif|jpg|png 結尾的URL?
如果對這種盜鏈你是堅決鄙視的,你還可以改變圖片,讓訪問盜鏈網站的用戶知道該網站正在盜用你的圖片。?
RewriteCond %{HTTP_REFERER} !^$?
RewriteCond %{HTTP_REFERER} !^http://(www\.)?example\.com/.*$ [NC]?
RewriteRule \.(gif|jpg|png)$ 你的圖片地址 [R=301,L]?
除了阻止圖片盜鏈鏈接,以上規則將其盜鏈的圖片全部替換成了你設置的圖片。?
你還可以阻止特定域名盜鏈你的圖片:?
RewriteCond %{HTTP_REFERER} !^http://(www\.)?leech_site\.com/ [NC]?
RewriteRule \.(gif|jpg|png)$ - [F,L]?
這個規則將阻止域名黑名單上所有的圖片鏈接請求。?
當然以上這些規則都是以{HTTP_REFERER}獲取域名為基礎的,如果你想改用成IP地址,用{REMOTE_ADDR}就可以了。
5.如果文件不存在重定向到404頁面?
如果你的主機沒有提供404頁面重定向服務,那么我們自己創建。?
RewriteCond %{REQUEST_FILENAME} !-f?
RewriteCond %{REQUEST_FILENAME} !-d?
RewriteRule .? /404.php [L]?
這里-f匹配的是存在的文件名,-d匹配的存在的路徑名。這段代碼在進行404重定向之前,會判斷你的文件名以及路徑名是否存在。你還可以在404頁面上加一個?url=$1參數:?
RewriteRule ^/?(.*)$ /404.php?url=$1 [L]?
這樣,你的404頁面就可以做一些其他的事情,例如默認信心,發一個郵件提醒,加一個搜索,等等。
6.重命名目錄?
如果你想在網站上重命名目錄,試試這個:?
RewriteRule ^/?old_directory/([a-z/.]+)$ new_directory/$1 [R=301,L]?
在規則里我添加了一個“.”(注意不是代表得所有字符,前面有轉義符)來匹配文件的后綴名。?
7.將.html后綴名轉換成.php?
前提是.html文件能繼續訪問的情況下,更新你的網站鏈接。?
RewriteRule ^/?([a-z/]+)\.html$ $1.php [L]?
這不是一個網頁重定向,所以訪問者是不可見的。讓他作為一個永久重定向(可見的),將FLAG修改[R=301,L]。?
8.創建無文件后綴名鏈接?
如果你想使你的PHP網站的鏈接更加簡潔易記-或者隱藏文件的后綴名,試試這個:?
RewriteRule ^/?([a-z]+)$ $1.php [L]?
如果網站混有PHP以及HTML文件,你可以用RewriteCond先判斷該后綴的文件是否存在,然后進行替換:?
RewriteCond %{REQUEST_FILENAME}.php -f?
RewriteRule ^/?([a-zA-Z0-9]+)$ $1.php [L]?
RewriteCond %{REQUEST_FILENAME}.html -f?
RewriteRule ^/?([a-zA-Z0-9]+)$ $1.html [L]?
如果文件是以.php為后綴,這條規則將被執行。
9.檢查查詢變量里的特定參數?
如果在URL里面有一個特殊的參數,你可用RewriteCond鑒別其是否存在:?
RewriteCond %{QUERY_STRING} !uniquekey=?
RewriteRule ^/?script_that_requires_uniquekey\.php$ other_script.php [QSA,L]?
以上規則將檢查{QUERY_STRING}里面的uniquekey參數是否存在,如果{REQUEST_URI}值為script_that_requires_uniquekey,將會定向到新的URL。?
10.刪除查詢變量?
Apache的mod_rewrite模塊會自動辨識查詢變量,除非你做了以下改動:?
a).分配一個新的查詢參數(你可以用[QSA,L]FLAG保存最初的查詢變量)?
b).在文件名后面加一個“?”(比如index.php?)。符號“?”不會在瀏覽器的地址欄里顯示。
11.用新的格式展示當前URI?
如 果這就是我們當前正在運行的URLs:/index.php?id=nnnn。我們非常希望將其更改成/nnnn并且讓搜索引擎以新格式展現。首先,我們 為了讓搜索引擎更新成新的,得將舊的URLs重定向到新的格式,但是,我們還得保證以前的index.php照樣能夠運行。是不是被我搞迷糊了??
實現以上功能,訣竅就在于在查詢變量中加了一個訪問者看不到的標記符“marker”。我們只將查詢變量中沒有出現“marker”標記的鏈接進行重定向,然后將原有的鏈接替換成新的格式,并且通過[QSA]FLAG在已有的參數加一個“marker”標記。以下為實現的方式:?
RewriteCond %{QUERY_STRING} !marker?
RewriteCond %{QUERY_STRING} id=([-a-zA-Z0-9_+]+)?
RewriteRule ^/?index\.php$ %1? [R=301,L]?
RewriteRule ^/?([-a-zA-Z0-9_+]+)$ index.php?marker &id=$1 [L]
這里,原先的URL:http://www.example.com/index.php?id=nnnn,不包含marker,所以被第一個規則永久重定向到http://www.example.com/nnnn,第二個規則將http://www.example.com/nnnn反定向到http://www.example.com/index.php?marker&id=nnnn,并且加了marker以及id=nnnn兩個變量,最后mod_rewrite就開始進行處理過程。
第二次匹配,marker被匹配,所以忽略第一條規則,這里有一個“.”字符會出現在http://www.example.com/index.php?marker?&id=nnnn中,所以第二條規則也會被忽略,這樣我們就完成了。
注意,這個解決方案要求Apache的一些擴展功能,所以如果你的網站放于在共享主機中會遇到很多障礙。
12.保證安全服務啟用?
Apache可以用兩種方法辨別你是否開啟了安全服務,分別引用{HTTPS}和{SERVER_PORT}變量:?
RewriteCond %{REQUEST_URI} ^secure_page\.php$?
RewriteCond %{HTTPS} !on?
RewriteRule ^/?(secure_page\.php)$?https://www.example.com/$1 [R=301,L]?
以上規則測試{REQUEST_URI}值是否等于我們的安全頁代碼,并且{HTTPS}不等于on。如果這兩個條件同時滿足,請求將被重定向到安全服務URI.另外你可用{SERVER_PORT}做同樣的測試,443是常用的安全服務端口?
RewriteCond %{REQUEST_URI} ^secure_page\.php$?
RewriteCond %{SERVER_PORT} !^443$?
RewriteRule ^/?(secure_page\.php)$?https://www.example.com/$1 [R=301,L]
13.在特定的頁面上強制執行安全服務?
遇到同一個服務器根目錄下分別有一個安全服務域名和一個非安全服務域名,所以你就需要用RewriteCond 判斷安全服務端口是否占用,并且只將以下列表的頁面要求為安全服務:?
RewriteCond %{SERVER_PORT} !^443$?
RewriteRule ^/?(page1|page2|page3|page4|page5)$?https://www.example.com/%1[R=301,L]?
以下是怎樣將沒有設置成安全服務的頁面返回到80端口:?
RewriteCond %{ SERVER_PORT } ^443$?
RewriteRule !^/?(page6|page7|page8|page9)$http://www.example.com%{REQUEST_URI} [R=301,L]
5、UrlRewrite配置步驟
1:開啟apache的url_rewrite模塊,也就是在httpd.conf中去掉這句話的注釋LoadModule rewrite_module modules/mod_rewrite.so
2:找到AllowOverride,把AllowOverride None修改成AllowOverride all(這個至觀重要,不做這個設置的話就算做了其它的操作,也是無效的)
3:在所需要進行rewrite的web的主目錄下添加.htaccess文件,添加上一句話:RewriteEngine on
4:再.htaccess下補充個人的重寫規則即可
PS:最初我是省略了步驟2,所以一直配置都是無效,但是把規則寫到httpd.conf中就有效了。今天找了很多資料看了步驟2是很重要,這個配置的含義就是讓apache去讀取對應的配置文件,.htaccess屬于配置文件之一,如果設置成為了None就不讓讀取了,肯定就不得行了
轉載于:https://www.cnblogs.com/tham/p/6827317.html
與50位技術專家面對面20年技術見證,附贈技術全景圖總結
以上是生活随笔為你收集整理的Apache URLRewrite 原理及配置实现的全部內容,希望文章能夠幫你解決所遇到的問題。