• thingkphp 路由实例


    我们已经了解了如何定义路由规则,下面我们来举个例子加深印象。

    假设我们定义了News控制器如下(代码实现仅供参考):

    1. namespace HomeController;
    2. use ThinkController;
    3. class NewsController extends Controller{
    4. public function read(){
    5. $New = M('New');
    6. if(isset($_GET['id'])) {
    7. // 根据id查询结果
    8. $data = $New->find($_GET['id']);
    9. }elseif(isset($_GET['name'])){
    10. // 根据name查询结果
    11. $data = $New->getByName($_GET['name']);
    12. }
    13. $this->data = $data;
    14. $this->display();
    15. }
    16. public function archive(){
    17. $New = M('New');
    18. $year = $_GET['year'];
    19. $month = $_GET['month'];
    20. $begin_time = strtotime($year . $month . "01");
    21. $end_time = strtotime("+1 month", $begin_time);
    22. $map['create_time'] = array(array('gt',$begin_time),array('lt',$end_time));
    23. $map['status'] = 1;
    24. $list = $New->where($map)->select();
    25. $this->list = $list;
    26. $this->display();
    27. }
    28. }

    定义路由规则如下:

    1. 'URL_ROUTER_ON' => true, //开启路由
    2. 'URL_ROUTE_RULES' => array( //定义路由规则
    3. 'new/:idd' => 'News/read',
    4. 'new/:name' => 'News/read',
    5. 'new/:yeard/:monthd' => 'News/archive',
    6. ),

    然后,我们访问: http://serverName/index.php/Home/new/8

    会匹配到第一个路由规则,实际执行的效果等效于访问: http://serverName/index.php/Home/News/read/id/8

    当访问: http://serverName/index.php/Home/new/hello

    会匹配到第二个路由规则,实际执行的效果等效于访问: http://serverName/index.php/Home/News/read/name/hello

    那么如果访问: http://serverName/index.php/Home/new/2012/03

    是否会匹配第三个路由规则呢?我们期望的实际执行的效果能够等效于访问: http://serverName/index.php/Home/News/archive/year/2012/month/03

    事实上却没有,因为http://serverName/index.php/Home/new/2012/这个URL在进行路由匹配过程中已经优先匹配到了第一个路由规则了,把2012当成id的值传入了,这种情况属于路由规则的冲突,解决办法有两个:

    1、调整定义顺序

    路由定义改成:

    1. 'URL_ROUTE_RULES' => array( //定义路由规则
    2. 'new/:yeard/:monthd' => 'News/archive',
    3. 'new/:idd' => 'News/read',
    4. 'new/:name' => 'News/read',
    5. ),

    接下来,当我们再次访问: http://serverName/index.php/Home/new/2012/03

    的时候,达到了预期的访问效果。所以如果存在可能规则冲突的情况,尽量把规则复杂的规则定义放到前面,确保最复杂的规则可以优先匹配到。但是如果路由规则定义多了之后,仍然很容易混淆,所以需要寻找更好的解决办法。

    2、利用完全匹配功能

    现在我们来利用路由的完全匹配定义功能,把路由定义改成:

    1. 'URL_ROUTE_RULES' => array( //定义路由规则
    2. 'new/:idd$' => 'News/read',
    3. 'new/:name$' => 'News/read',
    4. 'new/:yeard/:monthd$' => 'News/archive',
    5. ),

    在规则最后加上$符号之后,表示完整匹配当前的路由规则,就可以避免规则定义的冲突了。对于规则路由来说,简单的理解就是URL里面的参数数量或者类型约束要完全一致。 所以,如果我们访问 http://serverName/index.php/Home/new/2012/03/01

    的话,是不会匹配成功任何一条路由的。

    3、利用正则路由

    当然,解决问题的办法总是不止一种,对于复杂的情况,我们不要忘了使用正则路由规则定义,在你找不到解决方案的时候,正则路由总能帮到你。 要实现上面的同样路由功能的话,还可以用下面的规则定义:

    1. 'URL_ROUTE_RULES' => array( //定义路由规则
    2. '/^new/(d+)$/' => 'News/read?id=:1',
    3. '/^new/(w+)$/' => 'News/read?name=:1',
    4. '/^new/(d{4})/(d{2})$/' => 'News/achive?year=:1&month=:2',
    5. ),

    大理石平台精度等级

  • 相关阅读:
    IOS数据持久化之归档NSKeyedArchiver
    Java中导入、导出Excel
    IOS开发中多线程的使用
    深入分析动态管理Fragment
    IOS开发之数据sqlite使用
    如何在Eclipse和Tomcat的Debug过程中启用热部署
    在PHP中无法连接Memcached的解决办法
    Apache mod_rewrite规则重写的标志一览
    Java多线程中run(), start(), join(), wait(), yield(), sleep()的使用
    Centos5.8下编译安装PHP5.4和memcached, phalcon, yaf, apc
  • 原文地址:https://www.cnblogs.com/furuihua/p/11777398.html
Copyright © 2020-2023  润新知