[精讚] [會員登入]
3446

[APACHE] 關於RewriteCond $1

RewriteCond $1的意義和解釋

分享此文連結 //n.sfs.tw/11099

分享連結 [APACHE] 關於RewriteCond $1@新精讚
(文章歡迎轉載,務必尊重版權註明連結來源)
2019-10-24 15:32:28 最後編修
2017-05-17 09:10:17 By 張○○
 

在閱讀 codeIgniter 時,發現他們的rewrite 寫法[2],雖然知道作用,但不知道原理,直到看到[1]的說明才了解,筆記下來。

RewriteEngine on

RewriteBase /

RewriteCond $1 !^(index\.php|images|robots\.txt|$)

RewriteRule ^(.*)$ index.php/$1 [L,QSA]

[1]. 符合此regex,進行[2]
[2]. [1]中刮弧中內容,變成[2]的$1進行[3]的判斷是否符合
[3]. 判斷不符合,比對結束;判斷符合非 index.php或 image或rebots.txt 則進行[4]
[4]. 改寫 index.php/$1 L代表比對結束,QSA代表附上後面參數

終於懂了,再看 symfony (PHP framework) 的寫法

 RewriteCond %{REQUEST_FILENAME} !-f

 RewriteRule ^(.*)$ app.php [QSA,L]

和 Slim (PHP framework)中第一行只要檔案不存在,就改寫成 index.php

RewriteCond %{REQUEST_FILENAME} !-f

RewriteRule ^ index.php [QSA,L]

能幫助理解

參考資料

[1] RewriteCond $1 http://www.webmasterworld.com/apache/4330396.htm

[2] codeIgniter 說明 http://www.codeigniter.org.tw/user_guide/general/urls.html


原文 2013-09-02 01:22:36

END

你可能感興趣的文章

[Apache] 顯示或不顯示錯誤 php預設錯誤不顯示,有三種方法可以顯示或不顯示錯誤

[APACHE] Centos7,8設定 HSTS ( HTTP Strict Transport Security ) CENTOS7,CENTOS8 資安上需要設定的 HSTS的方法。

[HTTPS] Ubuntu +SSL +正式的CA 設定 利用正式的CA憑證,設定網站SSL,有別於過去使用的「未授權憑證」

強迫網頁預設編碼語系 大部分的瀏覽器如果編碼設成「自動偵測」時都能正確的分析。但世界並不會這麼平順完美,明明我這樣設定utf8他就是用big5丟出來...

[Apache] 自訂錯誤頁面及移掉歡迎頁 Apache 有一個歡迎頁,以正式網站來說,出現這頁有點不專業,該移除它..

[Centos] 解決資安的幾個問題 因為資安的關係,接到了一些弱點掃描出現的問題,解決方法做個整理。

隨機好文

[MAC] 截取螢幕畫面的方法 截取螢幕畫面的方法,在MAC中叫作螢幕快照,英文是screenshot

HP SAS硬碟leds燈號說明 HP SAS硬碟leds燈號(hp g7/g6系統適用)說明

[jQuery] select 元件的取值及給值 html中的元件select,在jquery中要如何使用?

Smarty安裝 smarty 是著名的樣版引擎,非常的好用,用多了突然發現拿掉smarty反而不會寫php了,以下是安裝過程..

網頁的標頭(head)搜尋引擎和FB最佳化 網頁的標頭(head)搜尋引擎和facebook最佳化