發現問題
最近在做項目發現一個奇怪的現象,我的路由配置裡有如下配置:
Route::group(array('prefix'=>'admin','before'=>'adminauth'),function(){ // 管理員登入 Route::get('/',function(){ return Redirect::to('admin/login'); }); Route::get('login','UserController@adminLogin');}
目的是無論使用者輸入”admin”,還是”admin/login”都能跳轉到登入介面。然而現實情況是輸入”admin”之後,瀏覽器會無限重新導向,firebug記錄如下:
GET /public/admin/ 301 Moved Permanently GET admin 301 Moved PermanentlyGET admin 301 Moved PermanentlyGET /public/admin/ 301 Moved PermanentlyGET admin 301 Moved PermanentlyGET /public/admin/ 301 Moved PermanentlyGET admin 301 Moved Permanently....
經過一番搜尋後實驗,終於得出結論,問題有兩點:
1.public目錄下正好有個admin目錄,存放後台相關js和css
2.laravel內建的.htaccess的這樣一條規則:
RewriteEngine On# Redirect Trailing Slashes...RewriteRule ^(.*)/$ /public/$1 [L,R=301] #注意這條 # Handle Front Controller...RewriteCond %{REQUEST_FILENAME} !-dRewriteCond %{REQUEST_FILENAME} !-fRewriteRule ^ index.php [L]
解釋一下原理:
訪問public/admin目錄時,apache會自動轉成”public/admin/”的形式,而這種形式正好符合重寫的規則,又被重寫回”public/admin”的形式。因為public/admin目錄確實存在,所以請求根本不會到達index.php。
所以故事就是這樣,因為301那條規則的存在,無限重新導向產生了。
解決方案:
1.不要把public目錄下已有的目錄名做為路由地址
2.301規則前加一條”RewriteCond %{REQUEST_FILENAME} !-d”,但是這樣會使該目錄被直接存取。建議生產環境中關掉apache的autoindex模組(呃,我發現我用的wamp關掉這個模組apache就啟動不了了- -!)。
補充:
經過一些實驗,建議將.htaccess檔案改成如下:
RewriteEngine On# Redirect Trailing Slashes...RewriteCond %{REQUEST_FILENAME} !-d #防止真實目錄導致迴圈重新導向RewriteRule ^(.*)/$ /public/$1 [L,R=301] # Handle Front Controller...#RewriteCond %{REQUEST_FILENAME} !-d #防止使用者直接開啟真實目錄RewriteCond %{REQUEST_FILENAME} !-fRewriteRule ^ index.php [L]