ThinkPHP路由详解 |
本文标签: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, 静态路由 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 但是,当我们访问http://localhost:8999/index.php/Home/new/top/var/test尽管URL地址前面也有new/top,然而由于静态路由是完整匹配的性质,所以不会匹配到index/top/type/top 以上所述就是本文的全部内容了,希望大家能够喜欢 。 |