CakeRequest是CakePHP默认的请求对象。该类用于对请求数据的处理与交互。在每一次请求过程中,CakeRequest对象都会被创建,并通过引用的方式传递到应用程序需要使用这些数据的层中(如控制器,视图)。默认的,CakeRequest对象被赋予$this->request,可以在控制器,视图和助手类中使用。通过控制器引用的方式,也可以在组件类中使用请求对象。总的来说,CakeRequest对象主要负责以下几个功能:
- 处理GET,POST,FILES数组,并以对象形式返回这些数据
- 提供发起请求的客户端相关信息,如headers,客户端IP地址,域名信息
- 提供获取请求参数的方法,包括数组及对象属性。
获取请求参数
CakeRequest提供了多个接口用于获取请求参数。第一种方式是通过数组索引的形式,第二种通过$this->request-params,第三种通过对象属性的形式。例如获取当前请求的控制器。
01
02
03
|
$this ->request[ 'controller' ];
$this ->request->controller;
$this ->request->params[ 'controller' ]
|
上述的三种方式都能获取到当前请求的控制器名。通过提供多种方式来获取请求参数,可以为应用程序提供移植、升级的各种便利。a,不仅控制器可以通过如上方式获取,所有的路由元素均可以通过这些接口获取到。
除了路由元素之外,b,最常使用的请求参数还有URL中的普通参数(Passed arguments)和命名参数()。这些参数同样可以通过请求对象的三个接口获取。
01
02
03
04
05
06
07
08
09
|
//passed arguments $this ->request[ 'pass' ]
$this ->request->pass
$this ->request->params[ 'pass' ]
//named parameters $this ->request[ 'named' ]
$this ->request->named
$this ->request->params[ 'named' ]
|
上面同样通过CakeRequest的三个接口获取到了普通参数和命名参数。c,需要注意的是,CakePHP有很多非常重要,同时非常有用的参数,这些参数都能够通过CakeRequest对象的请求参数中获取。
- plugin 处理当前请求的插件,没有则返回null
- controller 处理当前请求的控制器
- action 处理当前请求的控制器方法
- prefix 当前控制器的前缀。如admin_edit。在路由中配置。
- bare 通过requestAction()发起的请求包含的参数。
- requested 当请求来自requestAction()时,值为true。
获取查询字符串参数 Accessing Querystring parameters
这个在未做重写的PHP程序中是最为常见的URL形式,可以通过CakeRequest::$query获取到查询字符串参数。
01
02
03
|
// URL地址 /posts/index?page=1&sort=title $this ->request->query[ 'page' ]
$this ->request[ 'url' ][ 'page' ]
|
获取POST数据 Accessing POST data
所有通过POST形式传递的数据都可以通过CakeRequest::$data获取。所有表单中包含data前缀的域的数据,都可以通过移除data字符串,然后通过CakeRequest::$data获取到该值。例如。
01
02
|
//当一个表单域的name属性为data[Post][title]时,该值可以在提交的控制器中通过如下方式获取 $this -request->data[ 'Post' ][ 'title' ];
|
获取路径信息 Accessing path information
CakeRequest提供了关于当前应用程序的路径信息。CakeRequest::$base和CakeRequest::$webroot用于生成url地址相当不错,另外它们还能够自动判断当前程序是否在子目录当中。(这两个方法对于子目录的判断我没有使用过,以后会在这里补充更详细的使用方法)。
检查请求 Inspecting the request
检查不同的请求环境,在2.0版本之前,一般通过RequestHandlerComponent组建进行。新版本的CakePHP已经将这些方法统一到CakeRequest请求对象当中,并且提供了一个新的接口用于向后兼容。
01
02
|
$this ->request->is( 'post' );
$this ->request->isPost();
|
上述两种方式都可以检测当前请求是否通过POST发起。这里有扩展用于创建新的方式检测请求环境,如下所示。
01
02
03
04
05
06
07
08
09
10
11
12
13
14
15
16
|
// Add an environment detector. $this ->request->addDetector( 'post' , array ( 'env' => 'REQUEST_METHOD' , 'value' => 'POST' ));
// Add a pattern value detector. $this ->request->addDetector( 'iphone' , array ( 'env' => 'HTTP_USER_AGENT' , 'pattern' => '/iPhone/i' ));
// Add an option detector $this ->request->addDetector( 'internalIp' , array (
'env' => 'CLIENT_IP' ,
'options' => array ( '192.168.0.101' , '192.168.0.100' )
)); // Add a callback detector. Can either be an anonymous function or a regular callable. $this ->request->addDetector( 'awesome' , array ( 'callback' => function ( $request ) {
return isset( $request ->awesome);
})); |
框架默认的环境检测方式如下,
- is(‘get’) Check to see if the current request is a GET.
- is(‘put’) Check to see if the current request is a PUT.
- is(‘post’) Check to see if the current request is a POST.
- is(‘delete’) Check to see if the current request is a DELETE.
- is(‘head’) Check to see if the current request is HEAD.
- is(‘options’) Check to see if the current request is OPTIONS.
- is(‘ajax’) Check to see of the current request came with X-Requested-with = XmlHttpRequest.
- is(‘ssl’) Check to see if the request is via SSL
- is(‘flash’) Check to see if the request has a User-Agent of Flash
- is(‘mobile’) Check to see if the request came from a common list of mobile agents.
Interacting with other aspects of the request
这里再一次讲CakeRequest中关于路径、当前URL地址的一些方法和属性做下比较。
- $this->request->webroot 包含了当前根目录的路径
- $this->request->base 相当于PHP函数中获取的base path
- $this->request->here 获取当前请求的完整路径
- $this->request->query 包含了查询字符串参数
更多关于CakePHP的CakeRequest对象的属性及方法,可以参考官方提供的CakeRequest API。
相关推荐
`CakeRequest`是CakePHP默认使用的请求对象,它集中了多项功能,如请求数据的处理、环境检测等。对于每个HTTP请求,系统都会自动创建一个`CakeRequest`实例,并将其赋值给控制器中的`$this->request`变量。开发者...
- **CakePHP Request Cycle**: CakePHP 的请求处理流程包括接收 HTTP 请求、路由请求到适当的控制器动作、执行模型和视图逻辑以及发送响应给客户端。 - **Just the Start**: 本书不仅仅介绍了框架的基础知识,还提供...
该方法中创建了验证器对象,并定义了验证规则,然后使用请求数据进行验证。 **3. 创建视图** 在`src/Template/Valids`目录下创建一个名为`index.ctp`的文件,并添加以下代码: ```php if ($errors) { foreach ...
ARO (Access Request Object)**:ARO代表请求访问的主体,通常是用户、角色或任何其他可以登录并尝试访问资源的实体。 **3. ACL Tree**:在CakePHP中,ACOs和AROs被组织成一个树形结构,这使得权限控制更加灵活,...
在本文中,我们将深入探讨如何在CakePHP 2.x框架中实现过滤和搜索功能,以创建一个具有分页的动态用户界面。 CakePHP是基于MVC(模型-视图-控制器)架构的PHP开发框架,它提供了一套强大的工具来简化Web应用的开发。...
10. **请求(Request)和响应(Response)对象**:这些对象封装了HTTP请求和响应的相关信息,提供了一种处理HTTP交互的统一方式。 11. **错误处理和异常**:蛋糕PHP提供了内置的错误处理和异常机制,帮助开发者优雅...
2. **HTTP基础**:Symfony封装了HTTP协议,提供了Request和Response对象,使得处理HTTP请求和响应变得简单易懂。 3. **表单处理**:Symfony的表单组件提供了强大的表单创建和验证功能,支持自定义验证规则和错误...
1. **PHP语法基础**:包括变量声明($var),数据类型(如字符串、整型、数组、对象等),控制结构(if/else,for,while,switch等),函数定义和调用,以及类和对象的概念。 2. **PHP Web开发**:利用PHP与HTML、...