[精讚] [會員登入]
3124

[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

你可能感興趣的文章

PHP 7.0 升級到 PHP7.3 因為套件的關係,想把PHP7.0升到7.3 結果又退回原版本

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

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

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

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

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

我有話要說

>>

限制:留言最高字數1000字。 限制:未登入訪客,每則留言間隔需超過10分鐘,每日最多5則留言。

訪客留言

[無留言]

隨機好文

[札記] 2016.7~12月札記 札記,只是札記

世紀帝國征服者新版本--被遺忘的帝國 世紀帝國征服者新版本--被遺忘的帝國 世紀二代的征服者是精典遊戲中的精典,aofe更好玩...

設計的工作絕不接受比價 拿買陽春麵的價格想買牛肉麵,寧願倒掉也不賣

[CodeIgniter 3] 資料庫的使用方法整理1/2 --Select的使用 [CodeIgniter 3] 資料庫的使用方法整理:Select的使用

超扯童話血多-賣火柴小女孩 這個真的是太扯了,扯到一直笑,尤其是作者出來那段 因為他第一到第九會連播,笑滿累的。如果你看不懂的話表示你的大腦還滿正經