校园春色亚洲色图_亚洲视频分类_中文字幕精品一区二区精品_麻豆一区区三区四区产品精品蜜桃

主頁(yè) > 知識(shí)庫(kù) > yii2 開(kāi)發(fā)api接口時(shí)優(yōu)雅的處理全局異常的方法

yii2 開(kāi)發(fā)api接口時(shí)優(yōu)雅的處理全局異常的方法

熱門(mén)標(biāo)簽:咸寧銷售電銷機(jī)器人系統(tǒng) 電銷機(jī)器人問(wèn)門(mén)薩維品牌my 余姚電話機(jī)器人 百度地圖標(biāo)注偏差 開(kāi)發(fā)地圖標(biāo)注類網(wǎng)站 外呼系統(tǒng)能給企業(yè)帶來(lái)哪些好處 百度地圖怎樣標(biāo)注圖標(biāo) 400電話蘭州申請(qǐng)請(qǐng) 廣東廣州在怎么申請(qǐng)400電話

前言:個(gè)人覺(jué)得,學(xué)習(xí)或溫習(xí)一套Web框架,在快速閱讀一遍文檔后,應(yīng)從路由,控制器,請(qǐng)求/響應(yīng)對(duì)象,數(shù)據(jù)模型(Logic,Dao,Entity),全局異常處理幾個(gè)方面下手,這幾項(xiàng)了解后,框架上手就游刃有余了。然后我比較喜歡在開(kāi)工前整理好框架的全局異常處理,方便寫(xiě) api時(shí)錯(cuò)誤的統(tǒng)一響應(yīng)。

api接口的開(kāi)發(fā)過(guò)程中,我們需要對(duì)用戶數(shù)據(jù)進(jìn)行嚴(yán)格的校驗(yàn),防止非法輸入對(duì)服務(wù)產(chǎn)生安全問(wèn)題,在開(kāi)發(fā)過(guò)程中,我比較喜歡即時(shí)的以拋出異常的方式中斷請(qǐng)求的處理,并以全局異常處理器格式化處理后統(tǒng)一返回給客戶端。

今天就把 yii2 自帶的全局異常處理器改寫(xiě)至對(duì) api 友好(yii2yii\web\HttpException默認(rèn)對(duì) web 請(qǐng)求友好,都是以text/html的方式返回錯(cuò)誤描述,對(duì)api不友好,api當(dāng)然是json)。

注冊(cè)異常處理器

yii2也是以 controller/action 的方式定義一個(gè)異常處理器的,我們可以在 components=>errorHandler中自定義。

# config/web.php
'components' => [
  'errorHandler' => [
    'errorAction' => 'exception/handler'
  ]
]

異常處理器

定義相應(yīng)的異常處理器,app\actions\ErrorApiAction 繼承 yii\web\ErrorAction,可以拿到yii2為我們整理好的全局異常。

# controllers/ExceptionController.php
?php

namespace app\controllers;

use yii\web\Controller;

class ExceptionController extends Controller
{
  /**
   * 為 actionHandler 掛載獨(dú)立的 action
   * @return array
   */
  public function actions()
  {
    return [
      'handler' => [
        'class' => 'app\actions\ErrorApiAction',
      ]
    ];
  }
}

對(duì)api友好的錯(cuò)誤異常處理器,這里我也只是簡(jiǎn)單的把響應(yīng)格式改了一下,異常的上下文還是用yii2自帶的處理的。

#actions/ErrorApiAction.php
?php
/**
 * @author wangzhijian@styd.com
 * @date 2019-5-13 17:20:10
 * Api 全局錯(cuò)誤異常處理器
 */

namespace app\actions;

use Yii;
use yii\web\ErrorAction;
use yii\web\Response;

class ErrorApiAction extends ErrorAction
{
  public function run()
  {
    // 根據(jù)異常類型設(shè)定相應(yīng)的響應(yīng)碼
    Yii::$app->getResponse()->setStatusCodeByException($this->exception);
    // json 格式返回
    Yii::$app->getResponse()->format = Response::FORMAT_JSON;
    // 返回的內(nèi)容數(shù)據(jù)
    return [
      'msg' => $this->exception->getMessage(),
      'err' => $this->exception->getCode()
    ];
  }
}

異常實(shí)體

主要是簡(jiǎn)單的把狀態(tài)碼的傳遞封裝一下,用更容易理解的類名來(lái)代理傳遞。
exceptions/HttpException.php

?php
/**
 * app 異常基礎(chǔ)類
 */

namespace app\exceptions;

class HttpException extends \yii\web\HttpException
{
  public function __construct($message = null, $code = 0, \Exception $previous = null)
  {
    parent::__construct($this->statusCode, $message, $code, $previous);
  }
}

exceptions/HttpForbiddenException.php

?php
/**
 * 400 bad request
 */

namespace app\exceptions;

class HttpBadRequestException extends HttpException
{
  public $statusCode = 400;
}

exceptions/HttpUnauthorizedException.php

?php
/**
 * 401 unauthorized
 */

namespace app\exceptions;

class HttpUnauthorizedException extends HttpException
{
  public $statusCode = 401;
}

exceptions/HttpForbiddenException.php

?php
/**
 * 403 forbidden
 */

namespace app\exceptions;

class HttpForbiddenException extends HttpException
{
  public $statusCode = 403;
}

exceptions/HttpNotFoundException.php

?php
/**
 * 404 not found
 */

namespace app\exceptions;

class HttpNotFoundException extends HttpException
{
  public $statusCode = 404;
}

使用范例

在一些 service logic model 中根據(jù)需要即時(shí)拋出異常即可,上層控制器拿到的永遠(yuǎn)都是正常的返回?cái)?shù)據(jù),絕對(duì)的2xx響應(yīng)簇

throw new HttpBadRequestException("具體的非法描述", 4001);
throw new HttpUnauthorizedException("請(qǐng)認(rèn)證后訪問(wèn)");
throw new HttpForbiddenException("無(wú)權(quán)訪問(wèn)");
throw new HttpNotFoundException("請(qǐng)求資源不存在");

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

您可能感興趣的文章:
  • 實(shí)例講解如何在PHP的Yii框架中進(jìn)行錯(cuò)誤和異常處理
  • YII Framework教程之異常處理詳解

標(biāo)簽:臨沂 麗江 鷹潭 衡陽(yáng) 巴彥淖爾 十堰 重慶 銅陵

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《yii2 開(kāi)發(fā)api接口時(shí)優(yōu)雅的處理全局異常的方法》,本文關(guān)鍵詞  yii2,開(kāi)發(fā),api,接口,時(shí),優(yōu)雅,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問(wèn)題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無(wú)關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《yii2 開(kāi)發(fā)api接口時(shí)優(yōu)雅的處理全局異常的方法》相關(guān)的同類信息!
  • 本頁(yè)收集關(guān)于yii2 開(kāi)發(fā)api接口時(shí)優(yōu)雅的處理全局異常的方法的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    主站蜘蛛池模板: 同德县| 铜鼓县| 宁都县| 兴安县| 连南| 鄂尔多斯市| 寿宁县| 温泉县| 高密市| 繁昌县| 安化县| 玉龙| 穆棱市| 山阴县| 兴安盟| 独山县| 客服| 平武县| 集贤县| 庆阳市| 杭锦后旗| 河东区| 织金县| 嘉兴市| 乌什县| 行唐县| 胶南市| 盖州市| 达州市| 娱乐| 色达县| 淳化县| 石狮市| 青铜峡市| 昌吉市| 蓝田县| 农安县| 宜君县| 温宿县| 大安市| 天长市|