hyperf/doc/zh-hk/constants.md

118 lines
2.2 KiB
Markdown
Raw Normal View History

2019-12-12 16:24:04 +08:00
# 枚舉類
2019-07-31 16:17:16 +08:00
2019-12-12 16:24:04 +08:00
當您需要定義錯誤碼和錯誤信息時,可能會使用以下方式,
2019-07-31 16:17:16 +08:00
```php
<?php
class ErrorCode
{
const SERVER_ERROR = 500;
const PARAMS_INVALID = 1000;
public static $messages = [
self::SERVER_ERROR => 'Server Error',
2019-12-12 16:24:04 +08:00
self::PARAMS_INVALID => '參數非法'
2019-07-31 16:17:16 +08:00
];
}
2019-12-12 16:24:04 +08:00
$message = ErrorCode::messages[ErrorCode::SERVER_ERROR] ?? '未知錯誤';
2019-07-31 16:17:16 +08:00
```
2019-12-12 16:24:04 +08:00
但這種實現方式並不友好,每當要查詢錯誤碼與對應錯誤信息時,都要在當前 `Class` 中搜索兩次。所以框架提供了基於註解的枚舉類。
2019-07-31 16:17:16 +08:00
2019-12-12 16:24:04 +08:00
## 安裝
2019-07-31 16:17:16 +08:00
```
composer require hyperf/constants
```
## 使用
2019-12-12 16:24:04 +08:00
### 定義枚舉類
2019-07-31 16:17:16 +08:00
```php
<?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;
/**
2019-12-12 16:24:04 +08:00
* @Message("系統參數錯誤")
2019-07-31 16:17:16 +08:00
*/
const SYSTEM_INVALID = 700;
}
```
2019-12-12 16:24:04 +08:00
用户可以使用 `ErrorCode::getMessage(ErrorCode::SERVER_ERROR)` 來獲取對應錯誤信息。
2019-07-31 16:17:16 +08:00
2019-12-12 16:24:04 +08:00
### 定義異常類
2019-07-31 16:17:16 +08:00
2019-12-12 16:24:04 +08:00
如果單純使用 `枚舉類`,在異常處理的時候,還是不夠方便。所以我們需要自己定義異常類 `BusinessException`,當有異常進來,會根據錯誤碼主動查詢對應錯誤信息。
2019-07-31 16:17:16 +08:00
```php
<?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);
}
}
```
2019-12-12 16:24:04 +08:00
### 拋出異常
2019-07-31 16:17:16 +08:00
2019-12-12 16:24:04 +08:00
完成上面兩步,就可以在業務邏輯中,拋出對應異常了。
2019-07-31 16:17:16 +08:00
```php
<?php
declare(strict_types=1);
namespace App\Controller;
use App\Constants\ErrorCode;
use App\Exception\BusinessException;
class IndexController extends Controller
{
public function index()
{
throw new BusinessException(ErrorCode::SERVER_ERROR);
}
}
```