ThinkPHP路由详解
有了基本配置,我们就可以来访问我们的应用默认首页了。进入到项目目录,可以直接使用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
以上所述就是本文的全部内容了,希望大家能够喜欢。
上一篇: php实现将Session写入数据库
下一篇: Android如何禁止横屏竖屏的变换