当前位置: 首页 > 文档资料 > Yaf 用户手册 >

9.2. 使用样例

优质
小牛编辑
133浏览
2023-12-01

要使得yaf在命令行模式下运行, 有俩种方式, 第一种方式专门为用Yaf开发Contab等任务脚本设计的方式, 这种方式下, 对Yaf的唯一要求就是能自动加载所需要的Model或者类库, 所以可以简单的通过Yaf_Application::execute来实现.

而第二种方式, 是为了在命令行下模拟请求, 运行和Web请求一样的流程, 从而可以用来在命令行下测试我们的Yaf应用, 对于这种方式, 唯一的关键点就是请求体, 默认的请求是由yaf_application实例化, 并且交给yaf_dispatcher的, 而在命令行模式下, Yaf_Application并不能正确的实例化一个命令行请求, 所以需要变更一下, 请求需要手动实例化.

例 9.1. 实例化一个Yaf_Request_Simple

 <?php
 $request = new Yaf_Request_Simple();
 print_r($requst);
 

如上面的例子, Yaf_Request_Simple的构造函数可以不接受任何参数, 在这种情况下, Yaf_Request_Simple会在命令行参数中, 寻找一个字符串参数, 如果找到, 则会把请求的request_uri置为这个字符串.

注意
当然, Yaf_Request_Simple是可以接受5个参数的, 具体的可见Yaf_Request_Simple类说明.

现在让试着运行上面的代码:

例 9.2.

 $ php request.php 
 
输出:
 Yaf_Request_Simple Object
 (
 [module] => 
 [controller] => 
 [action] => 
 [method] => CLI
 [params:protected] => Array
 (
 )
 [language:protected] => 
 [_base_uri:protected] => 
 [uri:protected] => 
 [dispatched:protected] => 
 [routed:protected] => 
 )
 

现在让我们变更下我们的运行方式:

例 9.3.

 $ php request.php  "request_uir=/index/hello"
 
输出:
 Yaf_Request_Simple Object
 (
 [module] => 
 [controller] => 
 [action] => 
 [method] => CLI
 [params:protected] => Array
 (
 )
 [language:protected] => 
 [_base_uri:protected] => 
 [uri:protected] => index/hello  //注意这里
 [dispatched:protected] => 
 [routed:protected] => 
 )
 

看到差别了么?

当然, 我们也可以完全指定Yaf_Request_Simple::__construct的5个参数:

例 9.4. 带参数实例化一个Yaf_Request_Simple

 <?php
 $request = new Yaf_Request_Simple("CLI", "Index", "Controller", "Hello", array("para" => 2));
 print_r($requst);
 
运行输出:
 $ php request.php 
 Yaf_Request_Simple Object
 (
 [module] => Index
 [controller] => Controller
 [action] => Hello
 [method] => CLI
 [params:protected] => Array
 (
 [para] => 2
 )
 [language:protected] => 
 [_base_uri:protected] => 
 [uri:protected] => 
 [dispatched:protected] => 
 [routed:protected] => 1    //注意这里
 )
 

可以看到一个比较特别的就是, routed属性变为了TRUE, 这就代表着如果我们手动指定了构造函数的参数, 那么这个请求不会再经过路由, 而直接是路由完成状态.