跳转到内容

错误处理

SDK 抛出的所有错误都继承自单个基类型,因此你可以在一处捕获任何 SDK 错误,或者在需要不同响应时在特定子类上分支。TypeScript 和 Python SDK 的层次结构相同。

错误层次结构

Error
└── ImbraceError (基类 — 捕获所有 SDK 错误)
├── AuthError (401, 403 — 无效或过期的凭证)
├── ApiError (4xx/5xx — 请求被服务器拒绝)
└── NetworkError (超时、连接被拒绝、DNS 故障)

有关特定错误消息和已知修复,请参见故障排除


AuthError

当服务器返回 401403 时抛出 — 凭证无效、过期或已撤销。

import { AuthError } from "@imbrace/sdk";
try {
const me = await client.platform.getMe();
} catch (e) {
if (e instanceof AuthError) {
console.error("请重新认证:", e.message);
}
}

ApiError

针对所有其他 4xx 和 5xx 响应(在 429/5xx 的重试用尽后)抛出。

import { ApiError } from "@imbrace/sdk";
try {
await client.contacts.get("nonexistent_id");
} catch (e) {
if (e instanceof ApiError) {
console.error(`HTTP ${e.statusCode}: ${e.message}`);
// 例如 "HTTP 404: Contact not found"
}
}
属性类型描述
statusCodenumberHTTP 状态码
messagestring服务器响应中的错误消息

NetworkError

当请求从未到达服务器时抛出 — 超时、DNS 故障或连接重置。

import { NetworkError } from "@imbrace/sdk";
try {
await client.platform.getMe();
} catch (e) {
if (e instanceof NetworkError) {
console.error("无法连接 baseUrl:", e.message);
// 例如 "Request timed out after 30000ms"
}
}

捕获所有 SDK 错误

导入基类型以在单个块中处理任何 SDK 原始错误:

import {
ImbraceClient,
ImbraceError,
AuthError,
ApiError,
NetworkError,
} from "@imbrace/sdk";
try {
await client.platform.getMe();
} catch (e) {
if (e instanceof AuthError) return handleAuthError(e);
if (e instanceof ApiError) return handleApiError(e);
if (e instanceof NetworkError) return handleNetworkError(e);
if (e instanceof ImbraceError) return handleUnknown(e);
throw e; // 重新抛出非 SDK 错误
}

自动重试行为

两个 SDK 的 HTTP 传输层都使用指数退避重试瞬时故障。重试次数在语言间略有不同,但条件相同。

条件动作
HTTP 429(速率限制)最多重试 2 次
HTTP 5xx(服务器错误)最多重试 2 次
网络错误 / 超时最多重试 2 次
HTTP 401 / 403不重试 — 立即抛出 AuthError
HTTP 4xx(其他)不重试 — 立即抛出 ApiError

退避: 尝试之间间隔 2^retryCount 秒(2s → 4s)。最坏情况下总计:3 次尝试。


请求超时

在创建客户端时配置超时时间(默认:30 秒)。超时触发时,进行中的请求将被中止并抛出/引发 NetworkError

const client = new ImbraceClient({ timeout: 15_000 }); // 毫秒

异步错误处理(Python)

异步客户端引发相同的异常类型:

from imbrace import AsyncImbraceClient, AuthError, ApiError
async with AsyncImbraceClient() as client:
try:
me = await client.platform.get_me()
except AuthError:
print("请重新认证")
except ApiError as e:
print(f"[{e.status_code}] {e}")

最佳实践

// 1. 始终单独处理 AuthError — 凭证需要刷新
// 2. 记录 ApiError.statusCode — 400 = 错误参数,404 = 未找到,409 = 冲突
// 3. 将顶级入口点包装在 try/catch 中
// 4. 不要重试 AuthError — 在凭证修复之前无济于事
async function safeGetMe(client: ImbraceClient) {
try {
return await client.platform.getMe();
} catch (e) {
if (e instanceof AuthError) {
await refreshCredentials();
return await client.platform.getMe();
}
throw e;
}
}