Laravel 5.5中為響應(yīng)請求提供的可響應(yīng)接口詳解
前言
Laravel 5.5 也將會是接下來的一個 LTS(長期支持)版本。 這就意味著它擁有兩年修復(fù)以及三年的安全更新支持。Laravel 5.1 也是如此,不過它兩年的錯誤修復(fù)支持將在今年結(jié)束。
Laravel 5.5 的路由中增加了一種新的返回類型:可相應(yīng)接口( Responsable )。該接口允許對象在從控制器或者閉包路由中返回時自動被轉(zhuǎn)化為標(biāo)準(zhǔn)的 HTTP 響應(yīng)接口。任何實(shí)現(xiàn) Responsable 接口的對象必須實(shí)現(xiàn)一個名為 toResponse() 的方法,該方法將對象轉(zhuǎn)化為 HTTP 響應(yīng)對象。
看示例:
use Illuminate\Contracts\Support\Responsable;
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 類如今可以在準(zhǔn)備響應(yīng)內(nèi)容時檢查這種(實(shí)現(xiàn)了 Responsable 接口的)類型:
if ($response instanceof Responsable) {
$response = $response->toResponse();
}
假如你在 App\Http\Responses 命名空間下用多個響應(yīng)類型來組織你的響應(yīng)內(nèi)容,可以參考下面這個示例。該示例演示了如何支持 Posts (多個實(shí)例組成的 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(),
];
});
}
}
以上只是一個模擬簡單應(yīng)用場景的基礎(chǔ)示例:返回一個 JSON 響應(yīng),但你希望響應(yīng)層不是簡單地用內(nèi)置實(shí)現(xiàn)把對象 JSON 化,而是要做一些內(nèi)容處理。以上示例同時假設(shè) App\Http\Responses\Response 這個類能提供一些基礎(chǔ)的功能。當(dāng)然響應(yīng)層也可以包含一些轉(zhuǎn)換代碼(類似 Fractal ),而不是直接在控制器里做這樣的轉(zhuǎn)換。
與上面示例中的 PostIndexResponse 類協(xié)作的控制器代碼類似以下這樣:
如果你想了解更多有關(guān)這個接口的細(xì)節(jié),可以查看項目中 相關(guān)代碼的 commit .
總結(jié)
以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,如果有疑問大家可以留言交流,謝謝大家對腳本之家的支持。
- 讓Laravel API永遠(yuǎn)返回JSON格式響應(yīng)的方法示例
- Laravel+Dingo/Api 自定義響應(yīng)的實(shí)現(xiàn)
- laravel http 自定義公共驗證和響應(yīng)的方法
- Laravel5.1 框架Request請求操作常見用法實(shí)例分析
- 跟我學(xué)Laravel之請求與輸入
- 跟我學(xué)Laravel之請求(Request)的生命周期
- 解決laravel 出現(xiàn)ajax請求419(unknown status)的問題
- Laravel獲取當(dāng)前請求的控制器和方法以及中間件的例子
- laravel請求參數(shù)校驗方法
- Laravel框架處理用戶的請求操作詳解
- Laravel5.1 框架響應(yīng)基本用法實(shí)例分析
相關(guān)文章
Laravel (Lumen) 解決JWT-Auth刷新token的問題
今天小編就為大家分享一篇Laravel (Lumen) 解決JWT-Auth刷新token的問題,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2019-10-10
php實(shí)現(xiàn)微信企業(yè)付款到個人零錢功能
這篇文章主要為大家詳細(xì) 介紹了php實(shí)現(xiàn)微信企業(yè)付款到個人零錢功能,具有一定的參考價值,感興趣的小伙伴們可以參考一下2018-10-10
基于PHP生成靜態(tài)頁的實(shí)現(xiàn)方法
本篇文章是對PHP生成靜態(tài)頁的實(shí)現(xiàn)方法進(jìn)行了詳細(xì)的分析介紹。需要的朋友參考下2013-05-05
Zend Framework入門教程之Zend_Session會話操作詳解
這篇文章主要介紹了Zend Framework入門教程之Zend_Session會話操作,結(jié)合實(shí)例形式詳細(xì)分析了Zend_Session會話操作的具體使用技巧,需要的朋友可以參考下2016-12-12
Thinkphp5框架ajax接口實(shí)現(xiàn)方法分析
這篇文章主要介紹了Thinkphp5框架ajax接口實(shí)現(xiàn)方法,結(jié)合實(shí)例形式分析了thinkPHP5 ajax交互相關(guān)操作技巧,需要的朋友可以參考下2019-08-08
PHP框架Laravel中實(shí)現(xiàn)supervisor執(zhí)行異步進(jìn)程的方法
這篇文章主要給大家介紹了PHP框架Laravel中實(shí)現(xiàn)supervisor執(zhí)行異步進(jìn)程的方法,文中介紹的非常詳細(xì),相信對大家具有一定的參考學(xué)習(xí)價值,需要的朋友們下面來一起看看吧。2017-06-06

