热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

CakePHP2Request请求对象中文教程

CakeRequest是CakePHP默认的请求对象。该类用于对请求数据的处理与交互。在每一次请求过程中,CakeRequest对象都会被创建,并通过引用的方式传递到应用程序需要使用这些数据的层中(如控制器,视图)。默认的,CakeRequest对象被赋予$this->request,可以在控制器,视图和助手类中


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) {
    returnisset($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。


推荐阅读
  • ServletContext接口在Java Web开发中扮演着重要角色,它提供了一种方式来获取关于整个Web应用程序的信息。通过ServletContext,开发者可以访问初始化参数、共享数据以及应用资源。 ... [详细]
  • Microsoft即将发布WPF/E的CTP(Community Technology Preview)和SDK,标志着RIA(Rich Internet Application)技术的新里程碑。更多详情及下载链接请参见MSDN官方页面。 ... [详细]
  • Spring Boot 中静态资源映射详解
    本文深入探讨了 Spring Boot 如何简化 Web 应用中的静态资源管理,包括默认的静态资源映射规则、WebJars 的使用以及静态首页的处理方法。通过本文,您将了解如何高效地管理和引用静态资源。 ... [详细]
  • Servlet过滤器入门:实现与配置
    本文介绍如何在Java Web应用中实现和配置Servlet过滤器,通过实现`javax.servlet.Filter`接口来创建过滤器,并详细说明其在web.xml文件中的配置方法。 ... [详细]
  • 本文将详细介绍如何安装和使用 CactiEZ 的中文版本,帮助那些对英文界面不太熟悉的用户轻松掌握这一强大的网络监控工具。 ... [详细]
  • 本文探讨了浏览器的同源策略限制及其对 AJAX 请求的影响,并详细介绍了如何在 Spring Boot 应用中优雅地处理跨域请求,特别是当请求包含自定义 Headers 时的解决方案。 ... [详细]
  • 深入分析十大PHP开发框架
    随着PHP技术的发展,各类开发框架层出不穷,成为了开发者们热议的话题。本文将详细介绍并对比十款主流的PHP开发框架,旨在帮助开发者根据自身需求选择最合适的工具。 ... [详细]
  • 本文深入探讨网页游戏的开发流程,涵盖从程序框架设计到具体实现的技术细节,旨在为开发者提供全面的指导。 ... [详细]
  • 本文探讨了如何在JavaScript中动态地引用由PHP生成的变量,特别是在循环中变量名随迭代变化的情况。通过示例代码展示了实现这一功能的具体步骤。 ... [详细]
  • C# 对象转 JSON 字符串的方法与应用
    本文介绍如何在 C# 中使用一般处理程序(ASHX)将对象转换为 JSON 字符串,并通过设置响应类型为 application/json 来确保客户端能够正确解析返回的数据。同时,文章还提供了 HTML 页面中不依赖 jQuery 的 AJAX 方法来接收和处理这些 JSON 数据的具体实现。 ... [详细]
  • 在使用Ant Design的Tabs组件时,遇到了动画抖动的问题。本文详细记录了从发现问题到最终解决的过程,包括尝试的各种方法和最终解决方案。 ... [详细]
  • 本文介绍了ThinkPHP框架的基本概念及其主要特性。作为一款遵循Apache许可证的开源框架,ThinkPHP不仅支持多种平台和Web服务器,还提供了丰富的功能以适应不同的开发需求。 ... [详细]
  • 本文深入探讨了 Prototype.js 框架及其与 JavaScript 原生 toString() 方法之间的区别,适合对前端开发感兴趣的开发者阅读。文章将帮助读者理解两者在功能实现和应用场景上的不同,从而更好地利用这些工具进行高效编程。 ... [详细]
  • Final Cut Pro X for Mac v10.6.4 中文版 永久授权
    Final Cut Pro X 是专为 Mac 设计的专业级视频编辑软件,以其创新的编辑工具、强大的媒体管理和优化的视频输出功能著称。该版本支持最新的 iPhone 13 系列设备拍摄的‘电影效果’模式视频,是视频创作者不可或缺的利器。 ... [详细]
  • 我有这种ajax$.ajax({type:"POST",url:"bee_sesi_edit.php&# ... [详细]
author-avatar
mobiledu2502870747
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有