ThinkPHP路由详解


Posted in PHP onJuly 27, 2015

有了基本配置,我们就可以来访问我们的应用默认首页了。进入到项目目录,可以直接使用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 相关文章推荐
php4的彩蛋
Oct 09 PHP
php开发工具之vs2005图解
Jan 12 PHP
destoon实现调用图文新闻的方法
Aug 21 PHP
thinkphp判断访客为手机端或PC端的方法
Nov 24 PHP
Yii2增加验证码步骤详解
Apr 25 PHP
Adnroid 微信内置浏览器清除缓存
Jul 11 PHP
PHP中文字符串截断无乱码解决方法
Oct 10 PHP
php mysql_list_dbs()函数用法示例
Mar 29 PHP
PHP基于DateTime类解决Unix时间戳与日期互转问题【针对1970年前及2038年后时间戳】
Jun 13 PHP
PHP实现通过二维数组键值获取一维键名操作示例
Oct 11 PHP
Laravel 解决composer相关操作提示php相关异常的问题
Oct 23 PHP
聊聊 PHP 8 新特性 Attributes
Aug 19 PHP
ThinkPHP安装和设置
Jul 27 #PHP
教你在PHPStorm中配置Xdebug
Jul 27 #PHP
关于PHP开发的9条建议
Jul 27 #PHP
Laravel 中获取上一篇和下一篇数据
Jul 27 #PHP
php实现将Session写入数据库
Jul 26 #PHP
php检测文本的编码
Jul 26 #PHP
PHP中COOKIES使用示例
Jul 26 #PHP
You might like
曾在DC漫画界反派角色扮演的演员,谁才是你心目中的小丑之王?
2020/04/09 欧美动漫
php array_search() 函数使用
2010/04/13 PHP
IIS7.X配置PHP运行环境小结
2011/06/09 PHP
CI操作cookie的方法分析(基于helper类库)
2016/03/28 PHP
php使用str_shuffle()函数生成随机字符串的方法分析
2017/02/17 PHP
Yii框架数据库查询、增加、删除操作示例
2019/10/14 PHP
Yii 框架控制器创建使用及控制器响应操作示例
2019/10/14 PHP
laravel框架学习笔记之组件化开发实现方法
2020/02/01 PHP
js自动下载文件到本地的实现代码
2013/04/28 Javascript
jquery选择器之属性过滤选择器详解
2014/01/27 Javascript
JavaScript关闭当前页面(窗口)不带任何提示
2014/03/26 Javascript
js关于命名空间的函数实例
2015/02/05 Javascript
Javascript生成全局唯一标识符(GUID,UUID)的方法
2016/02/27 Javascript
Bootstrap自定义文件上传下载样式
2016/05/26 Javascript
Bootstrap 3多级下拉菜单实例
2017/11/23 Javascript
vue 左滑删除功能的示例代码
2019/01/28 Javascript
layui之数据表格--与后台交互获取数据的方法
2019/09/29 Javascript
Vue3.0的优化总结
2020/10/16 Javascript
python3下实现搜狗AI API的代码示例
2018/04/10 Python
Python使用修饰器进行异常日志记录操作示例
2019/03/19 Python
anaconda如何查看并管理python环境
2019/07/05 Python
python接口调用已训练好的caffe模型测试分类方法
2019/08/26 Python
python 中的paramiko模块简介及安装过程
2020/02/29 Python
Booking.com西班牙:全球酒店预订
2018/03/30 全球购物
经贸日语毕业生自荐信
2013/11/03 职场文书
玩具公司的创业计划书
2013/12/31 职场文书
预备党员思想汇报
2014/01/08 职场文书
校园之星获奖感言
2014/01/29 职场文书
对外汉语专业大学生职业生涯规划范文
2014/09/13 职场文书
科级干部群众路线教育实践活动个人对照检查材料
2014/09/19 职场文书
优秀共青团员事迹材料
2014/12/25 职场文书
布达拉宫导游词
2015/02/02 职场文书
陪护人员误工证明
2015/06/24 职场文书
2016年“世界气象日”广播稿
2015/12/17 职场文书
Go语言中的UTF-8实现
2021/04/26 Golang
永中文档在线转换预览基于nginx配置部署方案
2022/06/10 Servers