日誌巨集
最后更新于:2022-04-01 23:12:32
# 日誌巨集
### 前言
我們會用 Laravel 內建的 Response 去回應服務的訊息,我們可能會用的回應會像這樣:
~~~
// 建立 JSON 回應
return Response::json(['name' => 'KeJyun', 'Country' => 'Taiwan']);
return response()->json(['name' => 'KeJyun', 'Country' => 'Taiwan']);
// 建立 JSONP 回應
return Response::json(['name' => 'KeJyun', 'Country' => 'Taiwan'])
->setCallback($request->input('callback'));
return response()->json(['name' => 'KeJyun', 'Country' => 'Taiwan'])
->setCallback($request->input('callback'));
// 建立檔案下載的回應
return response()->download($pathToFile);
return response()->download($pathToFile, $name, $headers);
return response()->download($pathToFile)->deleteFileAfterSend(true);
~~~
在這樣的使用下,我們可以很容易的回應訊息給使用者,但是在伺服器發生程式例外錯誤 (Exception) 時,我們可能也需要回應像是這樣的資料:
~~~
return Response::json(['status' => 'failure', 'error_code' => '5566']);
return response()->json(['status' => 'failure', 'error_code' => '5566']);
~~~
在我們用 Laravel 做 API 給手機用的時候,更需要有這些錯誤狀態的資料,所以我們沒辦法直接像網頁一樣跳出整個的錯誤 debug 畫面
但我們若想在 API 回應給手機這樣的錯誤資訊時,也能夠將例外錯誤記錄下來,以便我們進行除錯,我們可以做一個 Response 的巨集,去處理紀錄我們的回應
### 建立服務提供者
我們在命令列輸入 `php artisan make:provider ResponseServiceProvider` 建立回應的服務提供者
~~~
$ php artisan make:provider ResponseServiceProvider
~~~
該服務提供者檔案會被建立在 `app/Providers/ResponseServiceProvider.php` 中,命名空間為 `App\Providers\ResponseServiceProvider`
> 我們不一定要將服務提供者的檔案放到 `app/Providers` 目錄中,我們可以依照自己專案的需求,將他移動到像是 `app/KeJyun/Providers` 目錄中,這樣命名空間就會變成 `App\KeJyun\Providers\ResponseServiceProvider`,檔案放置的位置隨自己專案需求而定,只要遵照 PSR-4 的規定去設定命名空間及檔案位置即可
我新增了一個名稱為 jsonLog 的 Response 巨集,該巨集會回應 json 資料,並依照記錄層級紀錄我們傳給他的資訊,ResponseServiceProvider 程式會像這樣
~~~
[
// 其他的服務提供者
'App\KeJyun\Providers\ResponseServiceProvider',
],
~~~
設定完之後,Laravel 在啟動時就會自動載入該服務提供者了
### 使用自定的 Response 巨集 jsonLog
在我們撰寫商業邏輯時若發生無法預期的例外狀況,我們會想要紀錄該例外狀況的資料,我們就可以這樣使用 Response jsonLog 巨集:
~~~
try{
// 商業邏輯處理
} catch (Exception $exception) {
$response_data = [
'status'=>'failure',
'error_code'=>5566,
];
return response()->jsonLog($response_data, $exception, 'alert');
}
~~~
這樣在系統發生預期之外的例外時,我們也有參考的資料可以幫我們進行除錯了!!
### 參考資料
- [HTTP 回應:回應巨集 - Laravel.tw](http://laravel.tw/docs/5.0/responses#response-macros)
- [服務提供者 - Laravel.tw](http://laravel.tw/docs/5.0/providers)
';