[精讚] [會員登入]
3557

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

[Apache] 利用.htaccess防盜圖 利用.htaccess防盜圖,同時也介紹一個產生防盜圖.htaccess檔的網站

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

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

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

UTF-8的網頁但IE8一片空白 UTF8編碼的網頁在Firefox 正常顯示、但IE8 就是空白,IE8編碼設定是「自動偵測」可是自動偵測到的是 big5...

隨機好文

PHP for sphinx 函式庫安裝 PECL/sphinx PHP>= 5.2.2 已經能原生支援 sphinx,可是預設的沒有裝,我們得自己裝才能用

[Windows7] 移除IE10及移除IE11 Windows7 不得已的情況要移除IE11或IE10怎麼做?

Linux shell 的date表示法 linux下SHELL中的date表示法

詭異的創業思維 創業的思維中,有多少銀彈,有多少技術,有多少人脈,有多少時間等等,每個都要考慮進去,以熱忱建立的關係脆弱的像蘇打餅乾一樣..

APACHE的記錄檔格式 LogFormat 語法 在APACHE中有定義一些記錄的語法模版 在 /etc/httpd/conf/httpd.conf 中: LogForm