# 路由定义
## 注册路由规则
> `route`目录下的任何路由定义文件都是有效的,默认的路由定义文件是`route.php`,但你完全可以更改文件名,或者添加多个路由定义文件(你可以进行模块定义区分,但最终都会一起加载)。
```
├─route 路由定义目录
│ ├─route.php 路由定义
│ ├─api.php 路由定义
│ └─... 更多路由定义
```
假设后面的路由定义内容我们统一在`route.php`文件里面定义,最基础的路由定义方法是:
> #### Route::rule('路由表达式','路由地址','请求类型');
除了路由表达式和路由地址是必须的外,其它参数均为可选。`5.1`版本推荐采用方法的方式定义请求类型、路由参数及变量规则。
例如注册如下路由规则:
```
// 注册路由到index模块的News控制器的read操作
Route::rule('new/:id','index/News/read');
```
我们访问:
```
http://serverName/new/5
```
会自动路由到:
```
http://serverName/index/news/read/id/5
```
并且原来的访问地址会自动失效。
可以在`rule`方法中指定请求类型(不指定的话默认为任何请求类型有效),例如:
```
Route::rule('new/:id','News/update','POST');
```
> 请求类型参数不区分大小写。
表示定义的路由规则在`POST`请求下才有效。
如果要定义`GET`和`POST`请求支持的路由规则,可以用:
```
Route::rule('new/:id','News/read','GET|POST');
```
不过通常我们更愿意使用对应请求类型的快捷方法,包括:
类型描述快捷方法GETGET请求getPOSTPOST请求postPUTPUT请求putDELETEDELETE请求deletePATCHPATCH请求patch\*任何请求类型any快捷注册方法的用法为:
> #### Route::快捷方法名('路由表达式','路由地址');
使用示例如下:
```
Route::get('new/:id','News/read'); // 定义GET请求路由规则
Route::post('new/:id','News/update'); // 定义POST请求路由规则
Route::put('new/:id','News/update'); // 定义PUT请求路由规则
Route::delete('new/:id','News/delete'); // 定义DELETE请求路由规则
Route::any('new/:id','News/read'); // 所有请求都支持的路由规则
```
注册多个路由规则后,系统会依次遍历注册过的满足请求类型的路由规则,一旦匹配到正确的路由规则后则开始执行最终的调度方法,后续规则就不再检测。
## 路由表达式
路由表达式统一使字符串定义,采用规则定义的方式(不支持直接使用正则表达式,但支持给某个变量定义正则,参考后面的变量规则部分)。
### 规则表达式
规则表达式通常包含静态地址和动态地址,或者两种地址的结合,例如下面都属于有效的规则表达式:
```
Route::rule('/', 'index'); // 首页访问路由
Route::rule('my', 'Member/myinfo'); // 静态地址路由
Route::rule('blog/:id', 'Blog/read'); // 静态地址和动态地址结合
Route::rule('new/:year/:month/:day', 'News/read'); // 静态地址和动态地址结合
Route::rule(':user/:blog_id', 'Blog/read'); // 全动态地址
```
> 规则表达式的定义以`/`为参数分割符(无论你的`PATH_INFO`分隔符设置是什么,请确保在定义路由规则表达式的时候统一使用`/`进行URL参数分割,除非是使用组合变量的情况)。
每个参数中以`:`开头的参数都表示动态变量,并且会自动绑定到操作方法的对应参数。
> 你的URL访问`PATH_INFO`分隔符使用`pathinfo_depr`配置,但无论如何配置,都不影响路由的规则表达式的路由分隔符定义。
### 可选定义
支持对路由参数的可选定义,例如:
```
Route::get('blog/:year/[:month]','Blog/archive');
```
变量用`[ ]`包含起来后就表示该变量是路由匹配的可选变量。
以上定义路由规则后,下面的URL访问地址都可以被正确的路由匹配:
```
http://serverName/index.php/blog/2015
http://serverName/index.php/blog/2015/12
```
采用可选变量定义后,之前需要定义两个或者多个路由规则才能处理的情况可以合并为一个路由规则。
> 可选参数只能放到路由规则的最后,如果在中间使用了可选参数的话,后面的变量都会变成可选参数。
### 完全匹配
规则匹配检测的时候默认只是对URL从头开始匹配,只要URL地址包含了定义的路由规则就会匹配成功,如果希望URL进行完全匹配,可以在路由表达式最后使用`$`符号,例如:
```
Route::get('new/:cate$', 'News/category');
```
这样定义后
```
http://serverName/index.php/new/info
```
会匹配成功,而
```
http://serverName/index.php/new/info/2
```
则不会匹配成功。
如果是采用
```
Route::get('new/:cate', 'News/category');
```
方式定义的话,则两种方式的URL访问都可以匹配成功。
如果需要全局进行URL完全匹配,可以在`app.php`中设置
```
// 开启路由完全匹配
'route_complete_match' => true,
```
### 额外参数
在路由跳转的时候支持额外传入参数对(额外参数指的是不在URL里面的参数,隐式传入需要的操作中,有时候能够起到一定的安全防护作用,后面我们会提到)。例如:
```
Route::get('blog/:id','blog/read?status=1&app_id=5');
```
上面的路由规则定义中额外参数的传值方式都是等效的。`status`和`app_id`参数都是URL里面不存在的,属于隐式传值,当然并不一定需要用到,只是在需要的时候可以使用。
### 路由标识
如果你需要快速的根据路由生成URL地址,可以在定义路由的时候指定生成标识(但要确保唯一)。
例如
```
// 注册路由到index模块的News控制器的read操作
Route::name('new_read')->rule('new/:id','index/News/read');
```
生成路由地址的时候就可以使用
```
url('new_read',['id'=>10]);
```
如果不定义路由标识的话,使用下面的方式生成
```
url('index/News/read',['id'=>10]);
```
> `V5.1.6+`版本开始,路由标识的用法调整,原来的用法:
```
// 注册路由到index模块的News控制器的read操作
Route::name('new_read')->rule('new/:id','index/News/read');
```
需要改为:
```
// 注册路由到index模块的News控制器的read操作
Route::rule('new/:id','index/News/read')->name('new_read');
```
因为后者更符合语义。
- 序言
- 基础
- 安装
- 开发规范
- 目录结构
- 配置
- 架构
- 架构总览
- 入口文件
- URL访问
- 模块设计
- 命名空间
- 容器和依赖注入
- Facade
- 钩子和行为
- 中间件
- 路由
- 路由定义
- 变量规则
- 路由地址
- 闭包支持
- 路由参数
- 路由缓存
- 跨域请求
- 注解路由
- 路由分组
- MISS路由
- 资源路由
- 快捷路由
- 路由别名
- 路由绑定
- 域名路由
- URL生成
- 控制器
- 控制器定义
- 前置操作
- 跳转和重定向
- 空操作和空控制器
- 分层控制器
- 资源控制器
- 请求
- 请求对象
- 请求信息
- 输入变量
- 请求类型
- HTTP头信息
- 伪静态
- 参数绑定
- 请求缓存
- 响应
- 响应输出
- 响应参数
- 重定向
- 数据库
- 连接数据库
- 查询构造器
- 查询数据
- 添加数据
- 更新数据
- 删除数据
- 查询表达式
- 链式操作
- 聚合查询
- 时间查询
- 高级查询
- 视图查询
- JSON字段
- 子查询
- 原生查询
- 查询事件
- 事务操作
- 监听SQL
- 存储过程
- 数据集
- 分布式数据库
- 模型
- 定义
- 新增
- 更新
- 删除
- 查询
- JSON字段
- 获取器
- 修改器
- 自动时间戳
- 只读字段
- 软删除
- 类型转换
- 数据完成
- 查询范围
- 模型输出
- 模型事件
- 模型关联
- 一对一关联
- 一对多关联
- 远程一对多
- 多对多关联
- 多态关联
- 关联预载入
- 关联统计
- 关联输出
- 视图
- 视图渲染
- 视图赋值
- 视图过滤
- 模板引擎
- 模板
- 变量输出
- 使用函数
- 运算符
- 原样输出
- 模板注释
- 模板布局
- 模板继承
- 包含文件
- 输出替换
- 标签库
- 内置标签
- 循环标签
- 比较标签
- 条件判断
- 资源文件加载
- 标签嵌套
- 原生PHP
- 定义标签
- 标签扩展
- 错误和日志
- 异常处理
- 日志处理
- 调试
- 调试模式
- Trace调试
- 性能调试
- SQL调试
- 变量调试
- 远程调试
- 验证
- 验证器
- 验证规则
- 错误信息
- 验证场景
- 路由验证
- 内置规则
- 独立验证
- 静态调用
- 表单令牌
- 杂项
- 缓存
- Session
- Cookie
- 多语言
- 分页
- 上传
- 命令行
- 启动内置服务器
- 自动生成目录结构
- 创建类库文件
- 生成类库映射文件
- 清除缓存文件
- 生成配置缓存文件
- 生成数据表字段缓存
- 生成路由映射缓存
- 自定义指令
- 扩展库
- 验证码
- 图像处理
- Time
- 数据库迁移工具
- Workerman
- MongoDb
- 单元测试
- 安全和性能
- 安全建议
- 优化建议
- 附录
- 助手函数
- 升级指导
- 更新日志