FuelPHP 请求和响应
HTTP 请求和 HTTP 响应在任何 Web 应用程序中都扮演着重要的角色。我们需要获取 http 请求的完整详细信息才能正确处理它。处理完后,我们需要通过http响应将处理后的数据发送给客户端。
FuelPHP 提供了优秀的 Request 和 Response 类来分别读写HTTP 请求和HTTP 响应。让我们学习本章中的 Request 和 Response 类。
请求
在典型的 Web 应用程序中,应用程序需要解析当前请求的详细信息。 Request 类提供了简单的方法来解析应用程序要处理的当前请求。 Request 还提供了一个选项,通过充当 http 客户端来创建新请求。
创建新请求使应用程序能够请求应用程序的其他部分 or 完全是另一个应用程序并显示结果。让我们在本章中学习如何解析传入的请求,并在 HMVC 请求章节中学习如何创建新请求。
解析请求
Request 类提供了三种方法来获取 http 请求的详细信息。它们如下,
active-它是一个静态方法,返回当前活动的 http 请求。
$currentRequest = Request::active();
param-它返回指定参数的值。它包含两个参数。第一个参数是参数名称,第二个参数是要返回的值,如果该参数在当前 http 请求中不可用。
$param = Request::active()->param('employee_name', 'none');
params-除了将所有参数作为数组返回之外,它与 param 相同。
$params = Request::active()->params();
示例
让我们创建一个简单的表单并使用请求类处理表单。
步骤 1-在员工控制器中创建一个新操作 action_request。
public function action_request() { }
步骤 2-调用请求方法以获取当前请求的所有参数。
public function action_request() { $params = Request::active()->params(); }
步骤 3-转储获取的参数数组。
public function action_request() { $params = Request::active()->params(); echo dump($params); }
Step 4-更改路由以在路由配置文件中包含参数, fuel/app/config/routes.php
'employee/request(/:name)?' => array('employee/request', 'name' => 'name'),
现在,请求新操作 http://localhost:8080/employee/request/Jon,它将显示以下响应。
回复
Response 类提供了创建 http 响应的选项。默认情况下,我们在大多数情况下不需要直接使用响应类。相反,我们使用 View(我们将在下一章学习)来创建 http 响应。 View 对开发人员隐藏 http 响应,并使用底层 Response 类将响应发送给客户端。在高级的情况下,我们直接使用Response类,创建一个完整的http响应。
创建响应
响应由标题和正文组成。主要标头是 http 状态代码。 Http 状态码是 HTTP 协议中定义的用于描述响应的标准代码。例如状态码,200表示请求成功。
Response 类提供了三个参数来创建 http 响应,
$body = "Hi, FuelPHP"; $headers = array ( 'Content-Type' => 'text/html', ); $response = new Response($body, 200, $headers);
让我们在员工控制器中创建一个新动作, action_response,如下所示。
public function action_response() { $body = "Hi, FuelPHP"; $headers = array ( 'Content-Type' => 'text/html', ); $response = new Response($body, 200, $headers); return $response; }
结果
方法
Response 类提供了很多操作 http 响应的方法。它们如下,
forge-它与上面看到的响应类构造函数相同。
return Response::forge("Hi, FuelPHP", 404);
redirect-它提供了重定向到 URL 而不是发送响应的选项。它包含以下参数,
a.url-目标网址 b.方法-重定向方法。 location(默认)和 refresh c.redirect_code-http 状态代码。默认值为 302、
// use a URL Response::redirect('http://some-domain/index', 'refresh'); // or use a relative URI Response::redirect('employee/list');
redirect_back-除了重定向到上一页之外,它类似于重定向方法。如果没有可用的后台页面,我们可以指定重定向页面。
// if there is no back page, go to the employee list page Response::redirect_back('/employee/list', 'refresh');
set_status-它提供了一个设置 http 状态代码的选项。
$response = new Response(); $response->set_status(404);
set_header-它提供了一个设置 http 标头的选项。
$response = new Response(); $response->set_header('Content-Type', 'application/pdf'); // replace previous value using third arguments $response->set_header('Content-Type', 'application/pdf', 'text/plain');
set_headers-与 set_header 相同,只是它提供了使用数组设置多个标题的选项。
$response = new Response(); $response->set_headers(array 'Content-Type' => 'application/pdf', 'Pragma' => 'no-cache', ));
get_header-它可以获取先前设置的标题详细信息。
$response = new Response(); $response->set_header('Pragma', 'no-cache'); // returns 'no-cache' $header = $response->get_header('Pragma'); // returns array('Pragma' => 'no-cache') $header = $response->get_header();
body-它提供了一个选项来设置 http 响应的正文。
$response = new Response(); $response->body('Hi, FuelPHP'); // returns 'Hi, FuelPHP' $body = $response->body();
send_headers-将标头发送到请求的客户端。 FuelPHP 使用此方法将响应发送到客户端。通常情况下,我们不需要使用这种方法。
$response->send_headers();
Send-与 send_headers 相同,但 HTTP 响应中可能会限制标头。
// send the headers as well $response->send(true); // only send the body $response->send(false); $response->send();
下一章:FuelPHP 视图
View 是 MVC 应用程序的表示层。它将应用程序逻辑与表示逻辑分开。当控制器需要生成 HTML、CSS 或任何其他内容时,它会将任务转发给视图引擎。FuelPHP 提供了一个简单而灵活的类 View,它 ...