传统的使用 enum 类来封装接口状态码,会存在一些局限。以下提供了一种更加简洁且灵活的封装方案:
封装方式
使用 enum 和 dataclass 相结合来封装状态码:
import json from enum import enum from dataclasses import dataclass, asdict from typing import any @dataclass class statusitem: code: int msg: str class status(enum): success = statusitem(200000, "success") no_auth = statusitem(300001, "no authorization!")
json 序列化
使用自定义的 jsonencoder 来序列化 statusitem 对象:
class enumencoder(json.jsonencoder): def default(self, obj): if isinstance(obj, status): return asdict(obj.value) return json.jsonencoder.default(self, obj)
封装响应
使用 dataclass 封装响应数据:
@dataclass class response: status: status data: any def json(self) -> str: return json.dumps(asdict(self), cls=enumencoder)
使用方式
response = Response(Status.SUCCESS, {"age": 100}) # 直接调用 json() 方法即可获取 JSON 字符串 json_str = response.json() print(json_str)
优势
- 代码更加简洁明了
- 灵活地支持自定义状态码和信息
- 方便地扩展和维护
- 响应数据的序列化和反序列化过程更加高效