Laravel 5.5 为响应请求提供的可响应接口
时间:2022-05-02
本文章向大家介绍Laravel 5.5 为响应请求提供的可响应接口,主要内容包括其使用实例、应用技巧、基本知识点总结和需要注意事项,具有一定的参考价值,需要的朋友可以参考一下。
Laravel 5.5 的路由中增加了一种新的返回类型:可相应接口(Responsable)。该接口允许对象在从控制器或者闭包路由中返回时自动被转化为标准的 HTTP 响应接口。任何实现 Responsable 接口的对象必须实现一个名为 toResponse()
的方法,该方法将对象转化为 HTTP 响应对象。看示例:
use IlluminateContractsSupportResponsable;
class ExampleObject implements Responsable
{
public function __construct($name = null)
{
$this->name = $name ?? 'Teapot';
}
public function status()
{
switch(strtolower($this->name)) {
case 'teapot':
return 418;
default:
return 200;
}
}
public function toResponse()
{
return response(
"Hello {$this->name}",
$this->status(),
['X-Person' => $this->name]
);
}
}
在路由中使用这个 ExampleObject
的时候,你可以这样做:
Route::get('/hello', function() {
return new ExampleObject(request('name'));
});
在 Laravel 框架中,Route
类如今可以在准备响应内容时检查这种(实现了 Responsable 接口的)类型:
if ($response instanceof Responsable) {
$response = $response->toResponse();
}
假如你在 AppHttpResponses
命名空间下用多个响应类型来组织你的响应内容,可以参考下面这个示例。该示例演示了如何支持 Posts
(多个实例组成的 Collection):
posts = $posts;
}
public function toResponse()
{
return response()->json($this->transformPosts());
}
protected function transformPosts()
{
return $this->posts->map(function ($post) {
return [
'title' => $post->title,
'description' => $post->description,
'body' => $post->body,
'published_date' => $post->published_at->toIso8601String(),
'created' => $post->created_at->toIso8601String(),
];
});
}
}
以上只是一个模拟简单应用场景的基础示例:返回一个 JSON 响应,但你希望响应层不是简单地用内置实现把对象 JSON 化,而是要做一些内容处理。以上示例同时假设 AppHttpResponsesResponse
这个类能提供一些基础的功能。当然响应层也可以包含一些转换代码(类似Fractal),而不是直接在控制器里做这样的转换。
与上面示例中的 PostIndexResponse
类协作的控制器代码类似以下这样:
<!--?php
namespace AppHttpControllers;
use AppHttpResponses;
class PostsController extends Controller
{
public function index()
{
$posts = AppPost::all();
return new ResponsesPostIndexResponse($posts);
}
}
</pre-->
<p>
如果你想了解更多有关这个接口的细节,可以查看项目中<a href="https://github.com/laravel/framework/commit/c0c89fd73cebf9ed56e6c5e69ad35106df03d9db">相关代码的 commit</a>.</p>
<div id="copyright">
<img alt="" src="https://secure.gravatar.com/avatar/16a16bbe262d086712d25908c61a034b?s=55&d=mm&r=g" srcset="https://secure.gravatar.com/avatar/16a16bbe262d086712d25908c61a034b?s=110&d=mm&r=g 2x" class="avatar avatar-55 photo" height="55" width="55"> <p>作者:<a itemprop="author" itemscope="" itemtype="http://schema.org/Person" href="https://ofcss.com" title="小李刀刀"><span itemprop="name">小李刀刀</span></a><br>
原文链接:<a href="https://ofcss.com/2017/10/31/laravel-55-responsable-interface-for-responses.html" title="Laravel 5.5 为响应请求提供的可响应接口">Laravel 5.5 为响应请求提供的可响应接口</a><br>
<a href="https://ofcss.com" title="裁纸刀下">裁纸刀下</a>版权所有,允许非商业用途转载,转载时请原样转载并标明来源、作者,保留原文链接。</p>
</div>
- php概述
- php教程
- php环境搭建
- PHP书写格式
- php变量
- php常量
- PHP注释
- php数组
- php字符串 string
- PHP整型 integer
- PHP浮点型 float
- php布尔型
- php数据类型之数组
- php数据类型之对象
- php数据类型之null
- php数据类型之间的转换
- php运算符
- php表达式
- PHP循环控制
- PHP流程控制
- php函数
- php全局变量
- PHP魔术变量
- php命名空间
- php 日期
- PHP包含文件
- php文件
- PHP 文件上传
- php Cookies
- php Sessions
- php email
- php安全email
- php错误处理
- PHP异常处理
- php过滤器
- PHP 高级过滤器
- php json
- php 表单
- PHP MySQL 简介
- PHP 连接 MySQL
- php创建数据库
- php 创建表
- php mysq 插入数据
- PHP MySQL 插入多条数据
- PHP MySQL 预处理语句
- php mysql 读取数据
- php mysql where
- PHP MySQL Order By
- PHP MySQL Update
- PHP MySQL Delete
- php ODBC
- SOCKET网络编程 (通俗易懂入门篇)
- 进程 · 全家桶
- Posix线程 它们那一大家子事儿,要觉得好你就收藏进被窝慢慢看(2)
- Posix线程 它们那一大家子事儿,要觉得好你就收藏进被窝里慢慢看 (1)
- 种树:二叉树、二叉搜索树、AVL树、红黑树、哈夫曼树、B树、树与森林
- 【Linux内核】进程管理
- Django后台管理界面修改(代码修改)
- OpsnSSH抓包分析 | SSH协议分析
- 搭建简易的物联网服务端和客户端-第三次增补(二十二)
- ReentrantLock源码解析
- Nodejs连接PostgreSQL
- ReentrantReadWriteLock源码解析
- LockSupport源码解析
- Nodejs定时自动截图并发送给邮箱
- StampedLock源码解析