1

由于CodeIgniter开箱即用,它支持每个唯一 url 一个控制器。所以,假设我的routes.php文件中有以下网址:

$route['default_controller']  = "homepage";
$route['404_override']        = "homepage/not_found";

$route['^products$']          = "product/list";
$route['^product/(:any)$']    = "product/details";

我的网址将如下所示:

  1. 产品列表 => http://www.mywebsite.com/products
  2. 产品详情 => http://www.mywebsite.com/product/my-custom-product

在我构建产品列表的控制器中,我为每个产品创建 url,如下所示:

$this->db->from('products');
$products_result = $this->db->get();

$data['products'] = array();
foreach ($products_result->result() as $row)
{
    $data['products'][] = array(
        'title' => $row->title,
        'image' => $row->image,
        'url'   => site_url('product/' . $row->url)
    );
}

$this->load->view('products/list_view', $data);

但是每个 url 都有太多的冗余。每次我想在某处回显时,我都必须写下 url。如果我想更改 url,我必须打开每个 php 文件并将它们全部替换。

问题:是否有一种“方法”可以用来调用控制器名称及其方法,并且该“方法”返回该控制器的 url?像这样的东西:

build_site_url('product/details', array('my-product-url'));

其中第一个参数是控制器及其方法(因为 url 模式只存在一个控制器),第二个参数是 url 部分的数组。

4

3 回答 3

1

您正在寻找的是一种称为反向路由的功能。目前 CodeIgniter 中没有内置这样的功能,而且我能找到的任何库都是在 2010 年完成的,所以可能不是最新的。

但是,那里有与反向路由相关的文章和拉取请求,因此如果您有足够的经验,您应该能够为您的应用程序组合一些东西。

否则,您最好的选择可能是为您最常见的 URL(如您的产品)创建帮助程序。所以你可以做类似的事情echo product_url('my-product-name');,你只需要在帮助函数中调整 URL。

于 2013-05-21T19:18:22.730 回答
0

我不确定您到底想要什么,但您可以使用_remap()函数覆盖控制器行为;

看:http ://ellislab.com/codeigniter/user-guide/general/controllers.html#remapping

例如

public function _remap($method){
   if ($method == 'product/details') {
     ///do what you want to do
   }
于 2013-05-20T11:30:31.177 回答
0

您可以在产品控制器中使用默认查找功能(在CI Routing 文档中描述;查看示例)。

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

第一个段为“product”的 URL,第二个段中的任何内容都将重新映射到“catalog”类和“product_lookup”方法。

或者您可以使用数据库驱动的路线。
将表 product_slugs 添加到您的 MySQL 数据库:

CREATE TABLE IF NOT EXISTS `product_slugs` (
  `id` bigint(20) NOT NULL auto_increment,
  `slug` varchar(192) collate utf8_unicode_ci NOT NULL
  PRIMARY KEY  (`id`),
  KEY `slug` (`slug`)
) ENGINE=MyISAM  DEFAULT CHARSET=utf8 COLLATE=utf8_unicode_ci AUTO_INCREMENT=1;

将 application/config/routes.php 中的代码替换为以下代码:

$route[ 'default_controller' ]  = 'main';
$route[ '404_override' ]        = 'error404';

require_once( BASEPATH .'database/DB'. EXT );
$db =& DB();
$query = $db->get( 'product_slugs' );
$result = $query->result();
foreach( $result as $row )
{
    $route[ $row->slug ] = 'product/detail/$1;
}

然后,您所要做的就是在创建产品条目时创建一条记录,然后您就完成了:

INSERT INTO `product_slugs` (`slug`) VALUES ('name-of-the-product');
于 2013-05-20T11:54:13.087 回答