程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> 網頁編程 >> PHP編程 >> PHP綜合 >> ThinkPHP路由詳解

ThinkPHP路由詳解

編輯:PHP綜合

有了基本配置,我們就可以來訪問我們的應用默認首頁了。進入到項目目錄,可以直接使用PHP內置服務器來開始訪問,比如:

php -S localhost:8999

浏覽器輸入localhost:8999就可以看到ThinkPHP的默認首頁了:一個笑臉。

在這裡,我們訪問到的是ThinkPHP自帶的默認入口文件index.php也就是訪問到的是IndexController的index()方法,這是因為ThinkPHP默認設置:

'DEFAULT_CONTROLLER'  => 'Index'

如果你查看過ThinkPHP/Conf/convention.php文件,應該就會明白這個其實就是設置默認的控制器。

關於控制器(Controller)我們後面會仔細說

了解這些基本知識之後,那麼如果我們需要訪問其它的頁面,訪問其他的控制器和方法呢?答案就在本節的路由教程中。

路由定義規則

在使用路由之前,確保你的URL支持PATH_INFO(或者兼容URL模式也可以,采用普通URL模式的情況下不支持路由功能)並且確認已開啟一下的路由設置:

'URL_ROUTER_ON'  => true

這裡涉及到兩個設置項,PATH_INFO和URL_ROUTER_ON,這些在ThinkPHP/Conf/convention.php文件都可以找到。

在滿足以上兩個條件之後,就可以配置路由規則了。在配置文件中使用URL_ROUTE_RULES參數進行配置,配置格式是一個數組,其格式為: '路由表達式'=>'路由地址和傳入參數'每個元素都代表一個路由規則,比如:

'URL_ROUTE_RULES'=>array(
  'blogs/:year/:month/:day' => array('Index/archive', 'status=1'),
  'blogs/:id'        => 'Index/read',
),

ThinkPHP按定義的順序依次匹配路由規則,一旦匹配到的話,就會定位到路由定義中的控制器和操作方法去執行(你可以傳入其他的參數),而後面的規則不會繼續匹配

以上的路由配置說明:在每個路由表達式中,:後面跟參數名稱,比如上面的:year,:month,:id都是參數名稱,以:id為例,它指向Index控制器的read方法,這個方法接受一個$id的參數:

public function read($id){
    echo "read page with" .$id;
  }

在浏覽器輸入http://localhost:8999/index.php/Home/blogs/2就可以看到

read page with 2

Home就代表Home模塊,你可以簡單地將它映射到相應的Home目錄,這是由於在默認的配置中

'DEFAULT_MODULE'    => 'Home'

你可以根據自己的需求修改,但本課依舊采用默認的Home模塊.

如果你還需要傳人額外的參數,像第一條的規則array('Index/archive', 'status=1')中的status一樣傳人,你看設置多個這樣的參數。

如果你嘗試在浏覽器輸入:

http://localhost:8999/index.php/Home/blogs/string

ThinkPHP也給我們返回了string,但在日常的開發中,我們通常需要限制:id變量是整數,那該怎麼做呢?只需要稍稍改動就可以了,寫成

'blogs/:id\d'        => 'Index/read',

以上\d表示限制變量id只能是數字。

對於可選參數,可以用[]包含表示,比如:

'blogs/:year/:month/[:day]' => array('Index/archive', 'status=1'),

上面的day現在就是可選參數了,你可以傳人,也可以不傳。

在ThinkPHP中,還支持在限制路由的後綴和使用正則路由。

限制路由後綴,通常使用在平時常見的html,htm等後綴,還是以上面的規則為例:

'blogs/:id'        => array('Index/read',array('ext'=>'html'))

你就可以限制這條規則只能在.html的路由後綴生效。

正則路由

正則本身就是一門很大的學問,在學習ThinkPHP的正則路由之前,最好是具備一定的正則表達式的基礎。

路由表達式支持的正則定義必須以/開頭,否則就視為規則表達式,比如:

'#^blog\/(\d+)$#' => 'Index/read'

這會解析為規則路由而不是正則路由,因為錄音表達式並沒有以/開始,所以,我們需要這樣寫:

'/^new\/(\d{4})\/(\d{2})$/' => 'Index/achive?year=:1&month=:2',
以上就是一條正確的正則路由。對於正則表達式中的每個正則規則子模式)部分(如\d{4}和\d{2}),如果需要在後面的路由地址中引用,可以采用:1、:2這樣的方式,序號就是子模式的序號

靜態路由

ThinkPHP框架其實還有一個路由機制叫靜態路由,這實際上就是規則路由的靜態簡化版,路由定義中不包含動態參數(如上面的路由規則中id參數),靜態路由不需要遍歷路由規則而是直接定位,因此執行效率會較高。靜態路由采用URL_MAP_RULES來定義規則:

'URL_ROUTER_ON'  => true,
'URL_MAP_RULES'=>array(
  'new/top' => 'Index/top?type=top'
)

由於Index/top?type=top中Index表示控制器,第一個top表示方法,所以我們需要在Index控制器中創建top方法:

public function top(){
    echo "top page </br>";
  }

根據上面這條規則,如果我們訪問到

http://localhost:8999/index.php/Home/new/top

其實我們訪問的是:

http://localhost:8999/index.php/Home/index/top/type/top
轉譯成就是new/top對應的是index控制器的top方法,傳人的參數為type,參數值為top,所以就有了index/top/type/top

但是,當我們訪問http://localhost:8999/index.php/Home/new/top/var/test盡管URL地址前面也有new/top,然而由於靜態路由是完整匹配的性質,所以不會匹配到index/top/type/top

以上所述就是本文的全部內容了,希望大家能夠喜歡。

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved