路由绑定-j9九游
可以使用路由绑定简化url或者路由规则的定义,绑定支持如下方式:
绑定到模块/控制器/操作
把当前的url绑定到模块/控制器/操作,最多支持绑定到操作级别,例如在路由配置文件中添加:
// 绑定当前的url到 index模块
route::bind('index');
// 绑定当前的url到 index模块的blog控制器
route::bind('index/blog');
// 绑定当前的url到 index模块的blog控制器的read操作
route::bind('index/blog/read');
该方式针对路由到模块/控制器/操作有效,假如我们绑定到了index模块的blog控制器,那么原来的访问url从
http://servername/index/blog/read/id/5
可以简化成
http://servername/read/id/5
如果定义了路由
route::get('index/blog/:id','index/blog/read');
那么访问url就变成了
http://servername/5
绑定到命名空间
把当前的url绑定到某个指定的命名空间,例如:
// 绑定命名空间
route::bind('\app\index\controller','namespace');
那么,我们接下来只需要通过
http://servername/blog/read/id/5
就可以直接访问 \app\index\controller\blog
类的read方法。
绑定到类
把当前的url直接绑定到某个指定的类,例如:
// 绑定到类
route::bind('\app\index\controller\blog','class');
那么,我们接下来只需要通过
http://servername/read/id/5
就可以直接访问 \app\index\controller\blog
类的read方法。
注意:绑定到命名空间和类之后,不会进行模块的初始化工作。
入口文件绑定
如果我们需要给某个入口文件绑定模块,可以使用下面两种方式:
常量定义
只需要入口文件添加bind_module
常量,即可把当前入口文件绑定到指定的模块或者控制器,例如:
// 定义应用目录
define('app_path', __dir__ . '/../application/');
// 绑定到index模块
define('bind_module','index');
// 加载框架引导文件
require __dir__ . '/../thinkphp/start.php';
自动入口绑定
如果你的入口文件都是对应实际的模块名,那么可以使用入口文件自动绑定模块的功能,只需要在应用配置文件中添加:
// 开启入口文件自动绑定模块
'auto_bind_module' => true,
当我们重新添加一个 public/demo.php
入口文件,内容和public/index.php
一样:
// 定义应用目录
define('app_path', __dir__ . '/../application/');
// 加载框架引导文件
require __dir__ . '/../thinkphp/start.php';
但其实访问 demo.php
的时候,其实已经自动绑定到了demo
模块。
文档最后更新时间:2018-04-25 19:35:10
未解决你的问题?请到「问答社区」反馈你遇到的问题