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 操作文件的一些FAQ总结
Feb 12 PHP
UCenter中的一个可逆加密函数authcode函数代码
Jul 20 PHP
php中使用ExcelFileParser处理excel获得数据(可作批量导入到数据库使用)
Aug 21 PHP
Win下如何安装PHP的APC拓展
Aug 07 PHP
PHP中使用TCPDF生成PDF文档实例
Jul 01 PHP
PHP连接SQLServer2005的方法
Jan 27 PHP
PHP实现适用于自定义的验证码类
Jun 15 PHP
Yii使用DeleteAll连表删除出现报错问题的解决方法
Jul 14 PHP
php外部执行命令函数用法小结
Oct 11 PHP
php基于curl实现的股票信息查询类实例
Nov 11 PHP
详解php中curl返回false的解决办法
Mar 18 PHP
php如何把表单内容提交到数据库
Jul 08 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
php学习之流程控制实现代码
2011/06/09 PHP
php好代码风格的阶段性总结
2016/06/25 PHP
几行代码轻松实现PHP文件打包下载zip
2017/03/01 PHP
基于JQuery实现CheckBox全选全不选
2011/06/27 Javascript
用Jquery实现滚动新闻
2014/02/12 Javascript
jquery幻灯片插件bxslider样式改进实例
2014/10/15 Javascript
基于BootStrap的Metronic框架实现页面链接收藏夹功能按钮移动收藏记录(使用Sortable进行拖动排序)
2016/08/29 Javascript
AngularJS自定义控件实例详解
2016/12/13 Javascript
原生和jQuery的ajax用法详解
2017/01/23 Javascript
AngularJS 防止页面闪烁的方法
2017/03/09 Javascript
Angular4 中常用的指令入门总结
2017/06/12 Javascript
vue-cli + sass 的正确打开方式图文详解
2017/10/27 Javascript
基于jQuery解决ios10以上版本缩放问题
2017/11/03 jQuery
react-native android状态栏的实现
2018/06/15 Javascript
linux 下以二进制的方式安装 nodejs
2020/02/12 NodeJs
vue element ui validate 主动触发错误提示操作
2020/09/21 Javascript
[07:57]2018DOTA2国际邀请赛寻真——PSG.LGD凤凰浴火
2018/08/12 DOTA
用Python的线程来解决生产者消费问题的示例
2015/04/02 Python
python中通过预先编译正则表达式提高效率
2017/09/25 Python
Python3实现的画图及加载图片动画效果示例
2018/01/19 Python
python集合是否可变总结
2019/06/20 Python
python+opencv3生成一个自定义纯色图教程
2020/02/19 Python
Python+redis通过限流保护高并发系统
2020/04/15 Python
python 提高开发效率的5个小技巧
2020/10/19 Python
详解Django中的FBV和CBV对比分析
2021/03/01 Python
美国猫狗药物和用品网站:PetCareRx
2017/01/05 全球购物
日本即尚网:JSHOPPERS.com(支持中文)
2019/12/03 全球购物
如何理解委托
2012/01/06 面试题
物业经理自我鉴定
2014/03/03 职场文书
捐助倡议书范文
2014/04/15 职场文书
酒店七夕情人节活动策划方案
2014/08/24 职场文书
社区四风存在问题及整改措施
2014/10/26 职场文书
实习推荐信格式模板
2015/03/27 职场文书
党委工作总结2015
2015/04/27 职场文书
青年志愿者活动感想
2015/08/07 职场文书
创业计划书之家教中心
2019/09/25 职场文书