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 SQLite类
May 07 PHP
php操作excel文件 基于phpexcel
Jul 02 PHP
PHP中防止直接访问或查看或下载config.php文件的方法
Jul 07 PHP
php使用json_encode对变量json编码
Apr 07 PHP
PHP版微信公众平台红包API
Apr 02 PHP
php读取der格式证书乱码解决方法
Jun 22 PHP
PHP魔术方法以及关于独立实例与相连实例的全面讲解
Oct 18 PHP
php判断是否连接上网络的方法实例详解
Dec 14 PHP
PHP中仿制 ecshop验证码实例
Jan 06 PHP
/etc/php-fpm.d/www.conf 配置注意事项
Feb 04 PHP
PHP+ajax实现获取新闻数据简单示例
May 08 PHP
基于PHP+Mysql简单实现了图书购物车系统的实例详解
Aug 06 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
apache和php之间协同工作的配置经验分享
2013/04/08 PHP
解析php中反射的应用
2013/06/18 PHP
php通过array_unshift函数添加多个变量到数组前端的方法
2015/03/18 PHP
php从文件夹随机读取文件的方法
2015/06/01 PHP
变量在 PHP7 内部的实现(一)
2015/12/21 PHP
thinkphp在低版本Nginx 下支持PATHINFO的方法分享
2016/05/27 PHP
PHP convert_cyr_string()函数讲解
2019/02/13 PHP
深入学习微信网址链接解封的防封原理visit_type
2019/08/15 PHP
php设计模式之工厂模式用法经典实例分析
2019/09/20 PHP
由prototype_1.3.1进入javascript殿堂-类的初探
2006/11/06 Javascript
用jquery来定位
2007/02/20 Javascript
javascript中文本框中输入法切换的问题
2013/12/10 Javascript
jQuery focus和blur事件的应用详解
2014/01/26 Javascript
jQuery()方法的第二个参数详解
2015/04/29 Javascript
jQuery插件FusionCharts绘制的2D条状图效果【附demo源码】
2017/05/13 jQuery
使用clipboard.js实现复制功能的示例代码
2017/10/16 Javascript
360提示[高危]使用存在漏洞的JQuery版本的解决方法
2017/10/27 jQuery
JS实现字符串翻转的方法分析
2018/08/31 Javascript
JavaScript链式调用实例浅析
2018/12/19 Javascript
vue组件开发之tab切换组件使用详解
2020/08/21 Javascript
构建Python包的五个简单准则简介
2015/06/15 Python
Python列表和元组的定义与使用操作示例
2017/07/26 Python
Python使用pyh生成HTML文档的方法示例
2018/03/10 Python
python爬虫神器Pyppeteer入门及使用
2019/07/13 Python
Pytorch加载部分预训练模型的参数实例
2019/08/18 Python
python 解决flask uwsgi 获取不到全局变量的问题
2019/12/22 Python
python实现音乐播放器 python实现花框音乐盒子
2020/02/25 Python
django日志默认打印request请求信息的方法示例
2020/05/17 Python
香港太阳眼镜网上商店:SmartBuyGlasses香港
2016/07/22 全球购物
美国真皮手袋品牌:GiGi New York
2017/03/10 全球购物
退休教师欢送会主持词
2014/03/31 职场文书
工业设计毕业生自荐信
2014/04/13 职场文书
访谈节目策划方案
2014/05/15 职场文书
2014班子“三严三实”对照检查材料思想汇报
2014/09/18 职场文书
受伤赔偿协议书
2014/09/24 职场文书
字节飞书面试promise.all实现示例
2022/06/16 Javascript