您好,登錄后才能下訂單哦!
這篇文章主要為大家展示了“Laravel中Route重定向的示例分析”,內容簡而易懂,條理清晰,希望能夠幫助大家解決疑惑,下面讓小編帶領大家一起研究并學習一下“Laravel中Route重定向的示例分析”這篇文章吧。
發現問題
最近在做項目發現一個奇怪的現象,我的路由配置里有如下配置:
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 Permanently GET admin 301 Moved Permanently GET /public/admin/ 301 Moved Permanently GET admin 301 Moved Permanently GET /public/admin/ 301 Moved Permanently GET 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} !-d RewriteCond %{REQUEST_FILENAME} !-f RewriteRule ^ 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} !-f RewriteRule ^ index.php [L]
以上是“Laravel中Route重定向的示例分析”這篇文章的所有內容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內容對大家有所幫助,如果還想學習更多知識,歡迎關注億速云行業資訊頻道!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。