ThinkPHP URL 路由简介

ThinkPHP URL 路由简介

 

简单的说,URL 路由就是允许你在一定规则下定制你需要的 URL 样子,以达到美化 URL ,提高用户体验,也有益于搜索引擎收录的目的。

例子

原本的 URL 为:

http://www.5idev.com/index.php/Products/Show/category/5/id/123

该 URL 的本意是显示第 5 分类中 id 为 123 的产品。经过 URL 路由改写后 URL 可以为:

http://www.5idev.com/index.php/product/5/123

如果使用 .htaccess 文件的 Rewrite 规则再把入口文件隐藏,则上面的 URL 可以进一步简化为:

http://www.5idev.com/product/5/123

这个 URL 地址就相对比较简单易容。

提示:使用 Apache 的 URL Rewrite 规则也能达到 URL 定制的功能,在此就不展开了,感兴趣的请参看 Apache Rewrite 相关的文章。

ThinkPHP URL 路由配置

在 ThinkPHP 中要使用 URL 路由功能,需要做如下配置:

项目配置文件 Conf/config.php 里面开启路由功能(设置为 true):

'URL_ROUTER_ON'	=> true,

路由规则定义

与 2.x 版本不同,3.0 路由规则定义于项目配置文件 config.php 内,格式为数组格式,具体定义规则又分为规则路由和正则路由。规则路由语法如下:

格式1:'路由规则'=>'[分组/模块/操作]?额外参数1=值1&额外参数2=值2...'
格式2:'路由规则'=>array('[分组/模块/操作]','额外参数1=值1&额外参数2=值2...') 
格式3:'路由规则'=>'外部地址'
格式4:'路由规则'=>array('外部地址','重定向代码') 

语法说明

  1. 路由规则即是我们要在 URL 中显示出来规则,后面元素值部分是实际的 URL 地址及参数
  2. 路由规则中如果以 : 开头,表示动态变量,否则为静态地址
  3. 格式2的额外参数可以传入数组或者字符串
  4. 路由规则支持变量的数字约束定义,例如:’product/:id\d’=>’Products/Show’
  5. 路由规则非数字变量支持排除,例如 ‘news/:cate^add|edit|delete’=>’News/category’
  6. 路由规则支持完整匹配定义,例如:’product/:id\d$’=>’Products/Show’
  7. 路由规则中的静态地址部分不区分大小写
  8. 外部地址中如果要引用动态变量, 采用 :1、:2 的方式
  9. 规则路由可以支持 全动态和动静结合定义,例如 ‘:user/blog/:id’=>’Home/Blog/user’

这些规则及语法说明比较晦涩难懂,下面会有实例来对照以便理解上述路由规则及语法说明。

如果在配置文件里定义了路由开启功能,系统在执行 Dispatch 解析的时候,会判断当前 URL 是否存在定义的路由名称,如果有就会按照定义的路由规则来进行 URL 解析。

ThinkPHP URL 路由实例

以本文开始的例子为例,看该路由是如何定义的。在项目配置文件 Conf/config.php 里定义如下规则:

//路由定义
'URL_ROUTE_RULES'=> array(
    'product/:category\d/:id\d'=>'Products/Show', //规则路由
),

当我们访问如下这个地址的时候:

http://www.5idev.com/index.php/product/5/123

会将该地址解析到 Products 模块的 Show 操作,并传入 get 参数 category=5&id=123。

如果有额外的固定参数,如 status=1,可以定义路由:

'product/:category\d/:id\d'=>'Products/Show?status=1', //规则路由

也即匹配下面这个 URL 地址:

http://www.5idev.com/index.php/product/5/123/1

上面都是按格式1来定义的路由,在有额外参数的情况下,可以转换为第2种定义格式:

'product/:category\d/:id\d'=>array('Products/Show','status=1') 

上面的路由规则中 \d 表示只匹配数字,当不加此约束时,则可匹配所有字符,这也是默认情况。如果要严格约定传入的参数格式,请使用正则路由定义规则

路由格式:外部地址

对于路由格式 3 和格式 4,则是检测到匹配的路由格式,则跳转到外部地址,区别是格式 4 有重定向代码,如 301 代表永久重定向。

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/113177.html原文链接:https://javaforall.net

(0)
上一篇 2021年10月23日 上午8:00
下一篇 2021年10月23日 上午9:00


相关推荐

  • Hive数据库概述

    Hive数据库概述Hive 属于数据仓库的概念范畴 主要用于进行数据分析用 不适合实时数据查询 可以完成海量数据的存储 存储在 HDFS 上 不需要类似关系数据库那样的固定格式限制 对应的表实际上就是 hadoophdfs 上的文件夹 表中数据相当于文件 具体介绍看下文 HIVE 结构 Hive 是建立在 Hadoop 上的数据仓库基础构架 它提供了一系列的工具 可以用来进行数据提取转化加载 ETL 这是一种可以存储 查询和分析存储在 Hadoop 中的大规模数据的机制 Hive 定义了简单的类 SQL 查询语言 称为 QL

    2026年3月17日
    1
  • Java快递物流查询接口,怎么接入物流接口API,如何根据单号查询物流跟踪的详细信息的Demo详细说明。

    Java快递物流查询接口,怎么接入物流接口API,如何根据单号查询物流跟踪的详细信息的Demo详细说明。Java 怎么写物流接口 怎么接入物流接口 如何根据单号查询物流跟踪的详细信息需求根据用户输入的订单号 我们的后台识别订单号并根据快递鸟查询快递 Api 接口 实现自动查询的功能 2 demo 实例本人自己运行过的 Demo gt 点我下载 3 应用场景 下图 这里写图片描述 4 实现步骤 4 1 本接口采用快递鸟物流接口申请快递鸟 API 接口网址 http www kdniao com YundanChaxun aspx4 2 点击进入快递鸟注册账号 然后登陆进去申请接口 申

    2025年11月25日
    5
  • 年终必知:GPT使用指南与技能提升攻略

    年终必知:GPT使用指南与技能提升攻略

    2026年3月15日
    2
  • 织梦dede列表调用图集的第一张图片大图原图地址(非缩略图)

    织梦dede列表调用图集的第一张图片大图原图地址(非缩略图)

    2021年9月24日
    41
  • Ubuntu安装主题_ubuntu系统安装教程

    Ubuntu安装主题_ubuntu系统安装教程这几款漂亮的主题在网上流传很久了,它们都出自Zgegblog作者,感谢他为我们带来这么棒的主题,而且安装非常方便,一共是九套主题,下面就是在ubuntu9.10中的安装方法:首先需要编辑/etc/apt/sources.list文件,在终端中输入:gksudogedit/etc/apt/sources.list在其中加入以下源:debhttp://p

    2025年11月12日
    4
  • 函数类型_C语言函数类型

    函数类型_C语言函数类型函数类型在ECMAScript中有三种函数类型:函数声明,函数表达式和函数构造器创建的函数。每一种都有自己的特点。1.函数声明这种函数类型的主要特点在于它们仅仅影响变量对象。该特点也解释了第二

    2022年8月5日
    9

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号