CodeIgniter框架URL路由总结


Posted in PHP onSeptember 03, 2014

URI 路由

一般来说,URI字符串有着和它唯一对应的控制器(controller)类/方法。URI的各个部分是如下模式(pattern):

example.com/class/function/id/

然而在一些例子中,你也许想重定向这种关系来调用一个不同的类/方法(class/function),而不是与URL一一对应(的调用).

例如,你可能想使你的URL采用这种原型(prototype):

example.com/product/1/

example.com/product/2/

example.com/product/3/

example.com/product/4/

一般情况下,URL的第二个部分表示方法名,不过在上面的例子中,它表示一个产品的ID。CodeIgniter可以实现这个功能,让用户可以重新定向(remap)URI处理程序.

设定你自己的路由规则

路由规则定义在application/config/routes.php 文件中. 在此文件中,你可以看到一个名为 $route的数组,它可以让你定义你自己的路由规则。 定义可以用两种方式: 通配符(wildcards) 或者 正则表达式(Regular Expressions)

通配符

一个典型的通配符路由看起来是这样的:

$route['product/(:num)'] = "catalog/product_lookup";

在一个路由中,数组的键包含着被匹配的URI,而数组的值包含着路由将被重定向的目的地.在上面的例子中,如果单词“product”出现在URL的第一个部分中,而且数字(:num)出现在URI的第二个部分中,"catalog"类和"product_lookup"方法将被替代使用(即将被重定向).

你可以匹配文字的值或者使用以下两种通配符类型:

:num 将匹配一个只包含有数字的segment(段).

:any 将匹配任何字符(可以是多个segment段).可以匹配多个值,如:

$route['product/(:any)'] = "catalog/product_lookup/$1/$2/$3/$4/$5"; //将整条url上的每一个参数全部传递给catalog控制器下的 product_lookup方法。

注意: 路由将会按照定义的顺序来运行.高层的路由总是优先于低层的路由.

例子

下面是一些简单的例子:

$route['journals'] = "blogs";

如果URL的第一个分段(类名)是关键字"journals",那么将会重定向到"blogs"类中处理.

$route['blog/joe'] = "blogs/users/34";

如果URL的前两个分段是"blog"和"joe",那么将会重定向到"blogs"类的"users"方法中处理.并且将ID"34"设为参数.

$route['product/(:any)'] = "catalog/product_lookup";

当"product"作为URL中第一个分段时, 无论第二分段是什么都将被重定向到"catalog"类的"product_lookup"方法.

$route['product/(:num)'] = "catalog/product_lookup_by_id/$1";

当“product”作为 URL 中第一个分段时,如果第二分段是数字,则将被重定向到“catalog”类,并传递所匹配的内容到“product_lookup_by_id”方法中。

重要提示: 不要在前面或后面加"/".

正则表达式

如果你喜欢可以使用正则表达式来自定义你的路由规则. 任何有效的正则表达式都是被允许的, 甚至逆向引用.

注意: 如果你使用逆向引用请将双反斜线语法替换为美元符语法(\\1 替换为 $1).

一个典型的正则表达式看起来像下面的样子:

$route['products/([a-z]+)/(\d+)'] = "$1/id_$2";

上例中, 类似于 products/shirts/123 的URI 将换成调用 shirts 控制器类的 id_123 方法.

你也可以混合使用通配符与正则表达式.

系统保留的路由

系统会保留两个路由:

第一个为系统默认的路由:

$route['default_controller'] = 'welcome';

这个路由表明了当URI中不包含要访问的类和控制器信息的(即只访问根目录的情况,如http://localhost/ci)将要加载哪个控制器。上例中,系统将加载 "welcome" 这个类(控制器)。你应该保证设置一个默认路由,不然你的首页将会显示 404 错误。

第二个为404页面的路由:

$route['404_override'] = '';

这个路由标识了如果请求的控制器无法访问的时候将加载哪个控制器。它相当于覆盖了默认的404错误页面(即提供了自己定义404页面的功能)。但它不会影响show_404()这个方法,这个方法依然会加载默认的位于application/errors/error_404.php的error_404.php页面。

重要: 保留的路由应该在所有通配符或正则表达式路由之前定义。

PHP 相关文章推荐
PHP环境搭建最新方法
Sep 05 PHP
php中支持多种编码的中文字符串截取函数!
Mar 20 PHP
使用php清除bom示例
Mar 03 PHP
Smarty中调用FCKeditor的方法
Oct 27 PHP
PHP文件上传判断file是否己选择上传文件的方法
Nov 10 PHP
Yii2验证器(Validator)用法分析
Jul 23 PHP
php curl中gzip的压缩性能测试实例分析
Nov 08 PHP
PHP 信号管理知识整理汇总
Feb 19 PHP
PHP实现时间比较和时间差计算的方法示例
Jul 24 PHP
thinkphp 中的volist标签在ajax操作中的特殊性(推荐)
Jan 15 PHP
PHP cookie与session会话基本用法实例分析
Nov 18 PHP
Laravel 集成微信用户登录和绑定的实现
Dec 27 PHP
Yii 快速,安全,专业的PHP框架
Sep 03 #PHP
Laravel框架数据库CURD操作、连贯操作总结
Sep 03 #PHP
Yii中render和renderPartial的区别
Sep 03 #PHP
PHP开发框架Laravel数据库操作方法总结
Sep 03 #PHP
Fedora下安装php Redis扩展笔记
Sep 03 #PHP
使用YUI+Ant 实现JS CSS压缩
Sep 02 #PHP
在Ubuntu 14.04上部署 PHP 环境及 WordPress
Sep 02 #PHP
You might like
自己做矿石收音机
2021/03/02 无线电
Linux下PHP连接Oracle数据库
2014/08/20 PHP
PHP+Mysql实现多关键字与多字段生成SQL语句的函数
2014/11/05 PHP
PHP实现上传图片到 zimg 服务器
2016/10/19 PHP
php 三大特点:封装,继承,多态
2017/02/19 PHP
php微信开发之关键词回复功能
2018/06/13 PHP
php利用array_search与array_column实现二维数组查找
2019/07/08 PHP
用js得到网页中所有的div的id
2020/10/19 Javascript
JS 自动安装exe程序
2008/11/30 Javascript
XENON基于JSON变种
2010/07/27 Javascript
jQuery拖动图片删除示例
2013/05/10 Javascript
JS画5角星方法介绍
2013/09/17 Javascript
使用jquery局部刷新(jquery.load)从数据库取出数据
2014/01/22 Javascript
NodeJS学习笔记之网络编程
2014/08/03 NodeJs
浅谈JavaScript中定义变量时有无var声明的区别
2014/08/18 Javascript
用原生js统计文本行数的简单示例
2016/08/19 Javascript
Angular2使用Guard和Resolve进行验证和权限控制
2017/04/24 Javascript
Chrome调试折腾记之JS断点调试技巧
2017/09/11 Javascript
详解如何使用node.js的开发框架express创建一个web应用
2018/12/20 Javascript
Vue CLI3.0中使用jQuery和Bootstrap的方法
2019/02/28 jQuery
解决layui弹框失效的问题
2019/09/09 Javascript
vue父子组件间引用之$parent、$children
2020/05/20 Javascript
node.js爬虫框架node-crawler初体验
2020/10/29 Javascript
Python完全新手教程
2007/02/08 Python
python的中异常处理机制
2018/08/30 Python
Python3爬虫学习之应对网站反爬虫机制的方法分析
2018/12/12 Python
解决sublime+python3无法输出中文的问题
2018/12/12 Python
python使用PyQt5的简单方法
2019/02/27 Python
整理的15个非常有用的 HTML5 开发教程和速查手册
2011/10/18 HTML / CSS
韩国爱茉莉太平洋化妆品美国站:Amore Pacific US
2016/10/28 全球购物
Alba Moda德国网上商店:意大利时尚女装销售
2016/11/14 全球购物
快时尚眼镜品牌,全国连锁眼镜店:LOHO眼镜生活
2018/10/08 全球购物
Jacadi Paris英国官网:法国童装品牌
2019/08/09 全球购物
aden + anais英国官网:美国婴儿贴身用品品牌
2019/09/08 全球购物
2014年化验室工作总结
2014/11/21 职场文书
2016廉洁教育心得体会
2016/01/20 职场文书