CodeIgniter配置之routes.php用法实例分析

URI 路由

本文实例分析了CodeIgniter配置之routes.php用法。分享给大家供大家参考,具体如下:

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

application/config/routes.php中定义了一个名为$route的数组,用来设置默认路由和404页面以及可以设置一些匹配方式。

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

默认的配置如下:

例如,你可能想使你的URL采用这种原型(prototype):
复制代码 代码如下:
example.com/product/1/
example.com/product/2/
example.com/product/3/
example.com/product/4/

$route['default_controller'] = "welcome";
$route['404_override'] = '';

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

default_controller指定默认的控制器名称,404_override指定当出现404时调用的控制器名称。有时候可能出现解析不成功,或者一直在默认页面,我们可以调用$this->router打印一下当前解析的控制器和Acion名称。比如可以在MY_Controller中如下打印:

设定你自己的路由规则

var_dump($this->router->fetch_directory());
var_dump($this->router->fetch_class());
var_dump($this->router->fetch_method());

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

确定下解析到哪个控制器了,
然后在看看URL的配置、服务器配置,以及可以在Router.php
和URI.php中调试下。

通配符

$route数组也可以通过通配符(:num,
:any)、正则来设置重写规则,下面是一些简单的例子:

  一个典型的通配符路由看起来是这样的:
复制代码 代码如下:
$route[‘product/(:num)’] = “catalog/product_lookup”;

1、将 请求解析到
处理。
Codeigniter并不支持包含查询字符串的重写规则,这个规则看起来应当这么写:

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

$route[‘admin/detail_(:num)’] = ‘admin/detail?user_id=$1’;

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

但实际上并未生效,程序匹配到admin/detail?user_id=1后用”/”分隔,索引为0的为控制器名,索引为1的为方法名,也就是会将上面的
detail?user_id=1赋值给方法名,结果可想而知就404了。搞清分隔原理后可以在detail后面增加一个斜杠,确保类名和方法名的正确,如:

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

$route[‘admin/detail_(:num)’] = ‘admin/detail/?user_id=$1’;

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

但此时又存在参数的获取问题了,会将第三个参数传递给方法,如果需要使用$_GET或者$this->input->get获取还需要对参数进行处理,如:

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

parse_str(ltrim($query_string, ‘?’), $_GET);

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

2、对PATH_INFO的URL形式重写规则还是比较支持的。如要实现

例子

$route[‘admin/(:num)’] = ‘admin/detail/$1’;

下面是一些简单的例子:

参数的获取就只能通过段落的方式来获取了。

复制代码 代码如下:
$route[‘journals’] = “blogs”;

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

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

最后,能使用CI来设置的路由还是建议使用CI来设置,不依赖服务器配置。

复制代码 代码如下:
$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中不包含要访问的类和控制器信息的(即只访问根目录的情况,如
“welcome”
这个类(控制器)。你应该保证设置一个默认路由,不然你的首页将会显示 404
错误。

第二个为404页面的路由:
复制代码 代码如下:
$route[‘404_override’] = ”;

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

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

发表评论

电子邮件地址不会被公开。 必填项已用*标注