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

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

  1. namespace Home\Controller;
  2. use Think\Controller;
  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/:id\d' => 'News/read',
  4. 'new/:name' => 'News/read',
  5. 'new/:year\d/:month\d' => '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/:year\d/:month\d' => 'News/archive',
  3. 'new/:id\d' => 'News/read',
  4. 'new/:name' => 'News/read',
  5. ),

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

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

2、利用完全匹配功能

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

  1. 'URL_ROUTE_RULES' => array( //定义路由规则
  2. 'new/:id\d$' => 'News/read',
  3. 'new/:name$' => 'News/read',
  4. 'new/:year\d/:month\d$' => '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. ),

大理石平台精度等级

thingkphp 路由实例的更多相关文章

  1. vue生成路由实例

    一.vue路由https://router.vuejs.org/zh-cn/1.bower下载vue-routervue的里的链接 <router-link to="/home&quo ...

  2. vue生成路由实例, 使用单个vue文件模板生成路由

    一.vue-loader与vue-router配合 $ cnpm install vue-router --save 二.生成vue-webpack模板 $ vue init webpack-simp ...

  3. Vue.js—组件快速入门及Vue路由实例应用

    上次我们学习了Vue.js的基础,并且通过综合的小实例进一步的熟悉了Vue.js的基础应用.今天我们就继续讲讲Vue.js的组件,更加深入的了解Vue,js的使用.首先我们先了解一下什么是Vue.js ...

  4. 链接(跳转)<router-link> 和 路由实例Router

    <router-link>和<router-link>传入的对象参数中包含path路径.name命名路由.params路径参数.query ?查询,并且如果提供了 path,p ...

  5. rails中path、url路径解析,routes信息,form_for剖析,link_to示例,路由实例说明

    原创,转载请注明http://www.cnblogs.com/juandx/p/3963023.html  rails中path.url路径解析,routes信息,form_for剖析,link_to ...

  6. react-router+webpack+gulp路由实例

    背景:新项目要开始了,有一种想要在新项目中使用react的冲动,应该也是一个单页面的应用,单页应用就涉及到一个路由的问题.于是最近在网上找了蛮多关于react-router的文章,也遇到了许多的坑,经 ...

  7. beego 各种形式的路由实例

    基本路由 基本路由就是和http.Handle和http.HandleFunc一样都是绑定固定的路径,比如绑定了4个路由映射: 定义的4个控制器中,匹配哪一个路由,就输出对应的控制名. beego.R ...

  8. vue路由实例

    router.js: import Vue from 'vue' import Router from 'vue-router' import Home from '@/components/Home ...

  9. AngularJS 路由和模板实例及路由地址简化方法

    最近一同事在学习AngularJS,在路由与模板的学习过程中遇到了一些问题,于是今天给她写了个例子,顺便分享出来给那些正在学习AngularJS的小伙伴们. 话说这AngularJs 开发项目非常的爽 ...

随机推荐

  1. idea使用tomcat运行maven打包的war

    注:此方法启动的tomcat只能够访问到本项目,包括tomcat的ROOT目录都访问不到 1.点击添加run  config ,选择添加tomcat  server

  2. ES7/ES8 语法学习

    作为一个前端开发者,感觉需要学习的东西贼多,ES6刚学会用没多久,又得学习了解ES7/ES8新增的东西,这里是看了大佬们文章的一点点总结以及摘抄的内容,给自己当笔记使用 内容转载自:https://w ...

  3. 杭电多校第一场-B-Operation

    题目描述 There is an integer sequence a of length n and there are two kinds of operations:0 l r: select ...

  4. Centos6.5 安装 LAMP

    Centos 安装 LAMP 系统: Centos 6.5 Apache 2.4 + PHP 7.2 + Mysql 5.7 准备工作 centos 查看版本 查看 centos版本 How to C ...

  5. Dart编程字符串

    String数据类型表示一系列字符.Dart字符串是一系列UTF 16代码单元. Dart中的字符串值可以使用 单引号 或 双引号 或 三引号 表示.单行字符串使用单引号或双引号表示.三引号用于表示多 ...

  6. 如何打造7*24h持续交付通道?阿里高级技术专家的5点思考

    我们对于研发效能的讨论,本质上是提高整个技术生态中的协同效率.如果仅从研发角度出发,技术团队要实现的终极目标是7*24小时的灵活发布窗口,以及更快的业务迭代能力. 7*24小时发布窗口的实现其实并不简 ...

  7. 给标签设置disabled属性后提交不了数据

    项目中遇到给select标签添加disabled属性然后提交表单的时候不能提交该表单的数据到后台, readonly属性对提交数据没有限制,但是readonly属性对radio.select.chec ...

  8. NX二次开发-UFUN获取面的内外边界UF_MODL_ask_loop_list_item

    NX11+VS2013 #include <uf.h> #include <uf_modl.h> #include <NXOpen/Face.hxx> #inclu ...

  9. vue中使用router全局守卫实现页面拦截

    一.背景 在vue项目中使用vue-router做页面跳转时,路由的方式有两种,一种是静态路由,另一种是动态路由.而要实现对路由的控制需要使用vuex和router全局守卫进行判断拦截(安全问题文章最 ...

  10. JS对象的可枚举属性和不可枚举属性

    昨天在写文章(转载)的时候发现了有些对象的方法是分可枚举性和不可枚举性的.简单的查了一下资料,今天来捋一捋啥是对象的可枚举啥是不可枚举. 可枚举性: 对象的每一个属性都有一个描述对象,用来描述和控制该 ...