mirror of
https://gitee.com/hyperf/hyperf.git
synced 2024-11-30 02:37:58 +08:00
bb3ed4815c
* Add translate docs action * Remove push Co-authored-by: sy-records <sy-records@users.noreply.github.com>
3.8 KiB
3.8 KiB
枚舉類
當您需要定義錯誤碼和錯誤信息時,可能會使用以下方式,
<?php
class ErrorCode
{
const SERVER_ERROR = 500;
const PARAMS_INVALID = 1000;
public static $messages = [
self::SERVER_ERROR => 'Server Error',
self::PARAMS_INVALID => '參數非法'
];
}
$message = ErrorCode::messages[ErrorCode::SERVER_ERROR] ?? '未知錯誤';
但這種實現方式並不友好,每當要查詢錯誤碼與對應錯誤信息時,都要在當前 Class
中搜索兩次,所以框架提供了基於註解的枚舉類。
安裝
composer require hyperf/constants
使用
定義枚舉類
通過 gen:constant
命令可以快速的生成一個枚舉類。
php bin/hyperf.php gen:constant ErrorCode
<?php
declare(strict_types=1);
namespace App\Constants;
use Hyperf\Constants\AbstractConstants;
use Hyperf\Constants\Annotation\Constants;
/**
* @Constants
*/
class ErrorCode extends AbstractConstants
{
/**
* @Message("Server Error!")
*/
const SERVER_ERROR = 500;
/**
* @Message("系統參數錯誤")
*/
const SYSTEM_INVALID = 700;
}
用户可以使用 ErrorCode::getMessage(ErrorCode::SERVER_ERROR)
來獲取對應錯誤信息。
定義異常類
如果單純使用 枚舉類
,在異常處理的時候,還是不夠方便。所以我們需要自己定義異常類 BusinessException
,當有異常進來,會根據錯誤碼主動查詢對應錯誤信息。
<?php
declare(strict_types=1);
namespace App\Exception;
use App\Constants\ErrorCode;
use Hyperf\Server\Exception\ServerException;
use Throwable;
class BusinessException extends ServerException
{
public function __construct(int $code = 0, string $message = null, Throwable $previous = null)
{
if (is_null($message)) {
$message = ErrorCode::getMessage($code);
}
parent::__construct($message, $code, $previous);
}
}
拋出異常
完成上面兩步,就可以在業務邏輯中,拋出對應異常了。
<?php
declare(strict_types=1);
namespace App\Controller;
use App\Constants\ErrorCode;
use App\Exception\BusinessException;
class IndexController extends AbstractController
{
public function index()
{
throw new BusinessException(ErrorCode::SERVER_ERROR);
}
}
可變參數
在使用 ErrorCode::getMessage(ErrorCode::SERVER_ERROR)
來獲取對應錯誤信息時,我們也可以傳入可變參數,進行錯誤信息組合。比如以下情況
<?php
use Hyperf\Constants\AbstractConstants;
use Hyperf\Constants\Annotation\Constants;
/**
* @Constants
*/
class ErrorCode extends AbstractConstants
{
/**
* @Message("Params %s is invalid.")
*/
const PARAMS_INVALID = 1000;
}
$message = ErrorCode::getMessage(ErrorCode::PARAMS_INVALID, ['user_id']);
// 1.2 版本以下 可以使用以下方式,但會在 1.2 版本移除
$message = ErrorCode::getMessage(ErrorCode::PARAMS_INVALID, 'user_id');
國際化
該功能僅在 v1.1.13 及往後的版本上可用
要使 hyperf/constants 組件支持國際化,就必須要安裝 hyperf/translation 組件並配置好語言文件,如下:
composer require hyperf/translation
相關配置詳見 國際化
<?php
// 國際化配置
return [
'params.invalid' => 'Params :param is invalid.',
];
use Hyperf\Constants\AbstractConstants;
use Hyperf\Constants\Annotation\Constants;
/**
* @Constants
*/
class ErrorCode extends AbstractConstants
{
/**
* @Message("params.invalid")
*/
const PARAMS_INVALID = 1000;
}
$message = ErrorCode::getMessage(ErrorCode::SERVER_ERROR, ['param' => 'user_id']);