该库提供了从 TypeScript 或 JavaScript 便捷访问 Anthropic REST API 的方式。
有关包含代码示例的 API 功能文档,请参阅 API 参考。本页面介绍 TypeScript 特定的 SDK 功能和配置。
npm install @anthropic-ai/sdk支持 TypeScript >= 4.9。
支持以下运行时:
"node" 环境(目前不支持 "jsdom")。dangerouslyAllowBrowser 设置为 true 来启用浏览器支持。请注意,目前不支持 React Native。
如果您对其他运行时环境感兴趣,请在 GitHub 上提交或支持相关 issue。
const client = new Anthropic({
apiKey: process.env["ANTHROPIC_API_KEY"] // This is the default and can be omitted
});
const message = await client.messages.create({
max_tokens: 1024,
messages: [{ role: "user", content: "Hello, Claude" }],
model: "claude-opus-4-8"
});
console.log(message.content);有关包括 Workload Identity Federation(工作负载身份联合)在内的身份验证选项,请参阅身份验证。
该库包含所有请求参数和响应字段的 TypeScript 定义。您可以按如下方式导入和使用它们:
const client = new Anthropic({
apiKey: process.env["ANTHROPIC_API_KEY"] // This is the default and can be omitted
});
const params: Anthropic.MessageCreateParams = {
max_tokens: 1024,
messages: [{ role: "user", content: "Hello, Claude" }],
model: "claude-opus-4-8"
};
const message: Anthropic.Message = await client.messages.create(params);每个方法、请求参数和响应字段的文档都可在 docstring 中找到,并会在大多数现代编辑器中悬停时显示。
您可以通过 usage 响应属性查看给定请求的确切用量,例如:
const message = await client.messages.create(/* ... */);
console.log(message.usage);
// { input_tokens: 25, output_tokens: 13 }SDK 支持使用 "Server Sent Events"(服务器发送事件),即 SSE 进行流式传输响应。
const client = new Anthropic();
const stream = await client.messages.create({
max_tokens: 1024,
messages: [{ role: "user", content: "Hello, Claude" }],
model: "claude-opus-4-8",
stream: true
});
for await (const messageStreamEvent of stream) {
console.log(messageStreamEvent.type);
}如果您需要取消流,可以从循环中 break 或调用 stream.controller.abort()。
该库为流式传输消息提供了多种便利功能,例如:
const anthropic = new Anthropic();
const stream = anthropic.messages
.stream({
model: "claude-opus-4-8",
max_tokens: 1024,
messages: [
{
role: "user",
content: "Say hello there!"
}
]
})
.on("text", (text) => {
console.log(text);
});
const message = await stream.finalMessage();
console.log(message);使用 client.messages.stream(...) 进行流式传输会暴露各种便利的辅助工具,包括事件处理程序和累积功能。
或者,您可以使用 client.messages.create({ ..., stream: true }),它仅返回流中事件的异步可迭代对象,因此使用更少的内存(它不会为您构建最终的消息对象)。
此 SDK 提供了辅助函数,使您可以轻松地在 Messages API 中创建和运行工具。您可以使用 Zod schema 或 JSON Schema 来描述工具的输入。然后,您可以使用 client.beta.messages.toolRunner() 方法运行这些工具。该方法会将所选模型生成的输入传递给正确的工具,并将结果传回模型。
有关工具使用的更多详细信息,请参阅使用 Claude 进行工具使用。
import { betaZodTool } from "@anthropic-ai/sdk/helpers/beta/zod";
import { z } from "zod";
const anthropic = new Anthropic();
const weatherTool = betaZodTool({
name: "get_weather",
inputSchema: z.object({
location: z.string()
}),
description: "Get the current weather in a given location",
run: (input) => {
return `The weather in ${input.location} is foggy and 60°F`;
}
});
const finalMessage = await anthropic.beta.messages.toolRunner({
model: "claude-opus-4-8",
max_tokens: 1000,
messages: [{ role: "user", content: "What is the weather in San Francisco?" }],
tools: [weatherTool]
});
console.log(finalMessage.content);要将工具中的错误报告回模型,请从 run 函数中抛出 ToolError。与普通的 Error 不同,ToolError 接受内容块,允许您在错误响应中包含图像或其他结构化内容:
import { ToolError } from "@anthropic-ai/sdk/lib/tools/BetaRunnableTool";
const screenshotTool = betaZodTool({
name: "take_screenshot",
inputSchema: z.object({ url: z.string() }),
run: async (input) => {
if (!isValidUrl(input.url)) {
throw new ToolError(`Invalid URL: ${input.url}`);
}
const result = await takeScreenshot(input.url);
if (result.error) {
// 包含错误截图,以便模型查看出错的地方
throw new ToolError([
{ type: "text", text: `Failed to load page: ${result.error}` },
{
type: "image",
source: { type: "base64", data: result.screenshot, media_type: "image/png" }
}
]);
}
return {
type: "image",
source: { type: "base64", data: result.screenshot, media_type: "image/png" }
};
}
});如果抛出普通的 Error,消息将被转换为文本内容块。
此 SDK 支持工具使用,也称为函数调用。有关更多详细信息,请参阅使用 Claude 进行工具使用。
此 SDK 提供了用于与 Model Context Protocol (MCP) 服务器集成的辅助函数。这些辅助函数将 MCP 类型转换为 Claude API 类型,从而减少使用 MCP 工具、提示和资源时的样板代码。
Claude API 还支持 mcp_servers 参数,允许 Claude 直接连接到远程 MCP 服务器。当您拥有可通过 URL 访问的远程服务器且仅需要工具支持时,请使用 mcp_servers。当您需要本地 MCP 服务器、提示、资源或对 MCP 连接进行更多控制时,请使用 MCP 辅助函数。
import {
mcpTools,
mcpMessages,
mcpResourceToContent,
mcpResourceToFile
} from "@anthropic-ai/sdk/helpers/beta/mcp";
import { Client } from "@modelcontextprotocol/sdk/client/index.js";
import { StdioClientTransport } from "@modelcontextprotocol/sdk/client/stdio.js";
const anthropic = new Anthropic();
// 连接到 MCP 服务器
const transport = new StdioClientTransport({ command: "mcp-server", args: [] });
const mcpClient = new Client({ name: "my-client", version: "1.0.0" });
await mcpClient.connect(transport);
// 使用 MCP 提示
const { messages } = await mcpClient.getPrompt({ name: "my-prompt" });
const response = await anthropic.beta.messages.create({
model: "claude-opus-4-8",
max_tokens: 1024,
messages: mcpMessages(messages)
});
console.log(response.content);
// 通过 toolRunner 使用 MCP 工具
const { tools } = await mcpClient.listTools();
const finalMessage = await anthropic.beta.messages.toolRunner({
model: "claude-opus-4-8",
max_tokens: 1024,
messages: [{ role: "user", content: "Use the available tools" }],
tools: mcpTools(tools, mcpClient)
});
console.log(finalMessage.content);
// 将 MCP 资源用作内容
const resource = await mcpClient.readResource({ uri: "file:///path/to/doc.txt" });
await anthropic.beta.messages.create({
model: "claude-opus-4-8",
max_tokens: 1024,
messages: [
{
role: "user",
content: [
mcpResourceToContent(resource),
{ type: "text", text: "Summarize this document" }
]
}
]
});
// 将 MCP 资源作为文件上传
const fileResource = await mcpClient.readResource({ uri: "file:///path/to/data.json" });
await anthropic.beta.files.upload({ file: mcpResourceToFile(fileResource) });如果 Claude API 不支持某个 MCP 值(例如,不支持的内容类型、不支持的 MIME 类型、非 http/https 资源链接),转换函数会抛出 UnsupportedMCPValueError。
此 SDK 在 client.messages.batches 命名空间下支持 Message Batches API。
Message Batches 接受一个请求数组,其中每个对象都有一个 custom_id 标识符,以及与标准 Messages API 完全相同的请求 params:
const batch = await client.messages.batches.create({
requests: [
{
custom_id: "my-first-request",
params: {
model: "claude-opus-4-8",
max_tokens: 1024,
messages: [{ role: "user", content: "Hello, world" }]
}
},
{
custom_id: "my-second-request",
params: {
model: "claude-opus-4-8",
max_tokens: 1024,
messages: [{ role: "user", content: "Hi again, friend" }]
}
}
]
});一旦 Message Batch 处理完成(由 .processing_status === 'ended' 指示),您可以使用 .batches.results() 访问结果
const results = await client.messages.batches.results(batch.id);
for await (const entry of results) {
if (entry.result.type === "succeeded") {
console.log(entry.result.message.content);
}
}对应于文件上传的请求参数可以以多种不同的形式传递:
File(或具有相同结构的对象)fetch 的 Response(或具有相同结构的对象)fs.ReadStreamtoFile 辅助函数的返回值请显式设置 content-type,因为 Files API 不会为您推断它:
import fs from "fs";
import Anthropic, { toFile } from "@anthropic-ai/sdk";
const client = new Anthropic();
// 如果您可以使用 Node 的 `fs` 模块,请使用 `fs.createReadStream()`:
await client.beta.files.upload({
file: await toFile(fs.createReadStream("/path/to/file"), undefined, {
type: "application/json"
})
});
// 或者,如果您可以使用 Web `File` API,则可以传入一个 `File` 实例:
await client.beta.files.upload({
file: new File(["my bytes"], "file.txt", { type: "text/plain" })
});
// 您也可以传入 `fetch` 的 `Response`:
await client.beta.files.upload({
file: await fetch("https://somesite/file")
});
// 或者传入 `Buffer` / `Uint8Array`
await client.beta.files.upload({
file: await toFile(Buffer.from("my bytes"), "file", { type: "text/plain" })
});
await client.beta.files.upload({
file: await toFile(new Uint8Array([0, 1, 2]), "file", { type: "text/plain" })
});当库无法连接到 API,或者 API 返回非成功状态码(即 4xx 或 5xx 响应)时,会抛出 APIError 的子类:
const message = await client.messages
.create({
max_tokens: 1024,
messages: [{ role: "user", content: "Hello, Claude" }],
model: "claude-opus-4-8"
})
.catch(async (err) => {
if (err instanceof Anthropic.APIError) {
console.log(err.status); // 400
console.log(err.name); // BadRequestError
console.log(err.headers); // {server: 'nginx', ...}
} else {
throw err;
}
});错误代码如下:
| 状态码 | 错误类型 |
|---|---|
| 400 | BadRequestError |
| 401 | AuthenticationError |
| 403 | PermissionDeniedError |
| 404 | NotFoundError |
| 409 | ConflictError |
| 422 | UnprocessableEntityError |
| 429 | RateLimitError |
| >=500 | InternalServerError |
| N/A | APIConnectionError |
有关调试请求的更多信息,请参阅请求 ID。
SDK 中的所有对象响应都提供一个 _request_id 属性,该属性从 request-id 响应标头添加,以便您可以快速记录失败的请求并将其报告给 Anthropic。
const message = await client.messages.create({
max_tokens: 1024,
messages: [{ role: "user", content: "Hello, Claude" }],
model: "claude-opus-4-8"
});
console.log(message._request_id); // req_018EeWyXxfu5pfWkrYcMdjWG某些错误默认会自动重试 2 次,并采用短暂的指数退避。 连接错误(例如,由于网络连接问题)、408 Request Timeout、409 Conflict、429 Rate Limit 和 >=500 Internal 错误默认都会重试。
您可以使用 maxRetries 选项来配置或禁用此功能:
// 为所有请求配置默认值:
const client = new Anthropic({
maxRetries: 0 // default is 2
});
// 或者,按请求单独配置:
await client.messages.create(
{
max_tokens: 1024,
messages: [{ role: "user", content: "Hello, Claude" }],
model: "claude-opus-4-8"
},
{ maxRetries: 5 }
);默认情况下,请求在 10 分钟后超时。但是,如果您指定了较大的 max_tokens 值并且_未_使用流式传输,则默认超时将使用以下公式动态计算:
const minimum = 10 * 60;
const calculated = (60 * 60 * maxTokens) / 128_000;
return calculated < minimum ? minimum * 1000 : calculated * 1000;这将导致最长 60 分钟的超时,按 max_tokens 参数缩放,除非在请求或客户端级别被覆盖。
您可以使用 timeout 选项进行配置:
// 为所有请求配置默认值:
const client = new Anthropic({
timeout: 20 * 1000 // 20 seconds (default is 10 minutes)
});
// 按请求覆盖:
await client.messages.create(
{
max_tokens: 1024,
messages: [{ role: "user", content: "Hello, Claude" }],
model: "claude-opus-4-8"
},
{ timeout: 5 * 1000 }
);超时时,会抛出 APIConnectionTimeoutError。
请注意,超时的请求将默认重试两次。
对于运行时间较长的请求,请考虑使用流式传输 Messages API。
避免在不使用流式传输的情况下设置较大的 max_tokens 值。
某些网络可能会在一段时间后断开空闲连接,这可能导致请求失败或超时而未收到 Anthropic 的响应。
如果非流式传输请求预计超过大约 10 分钟,此 SDK 也会抛出错误。
传递 stream: true 或在客户端或请求级别覆盖 timeout 选项可禁用此错误。
对于非流式传输请求,如果预期的请求延迟超过超时时间,将导致客户端终止连接并重试,而不会收到响应。
当 fetch 实现支持时,SDK 会设置 TCP socket keep-alive 选项,以减少某些网络上空闲连接超时的影响。
这可以通过配置自定义代理来覆盖。
Claude API 中的列表方法是分页的。
您可以使用 for await ... of 语法遍历所有页面中的项目:
async function fetchAllMessageBatches() {
const allMessageBatches = [];
// 根据需要自动获取更多页面。
for await (const messageBatch of client.messages.batches.list({ limit: 20 })) {
allMessageBatches.push(messageBatch);
}
return allMessageBatches;
}或者,您可以一次请求一个页面:
let page = await client.messages.batches.list({ limit: 20 });
for (const messageBatch of page.data) {
console.log(messageBatch);
}
// 提供了用于手动分页的便捷方法:
while (page.hasNextPage()) {
page = await page.getNextPage();
// ...
}SDK 会自动发送设置为 2023-06-01 的 anthropic-version 标头。
如果需要,您可以通过在每个请求的基础上设置默认标头来覆盖它。
请注意,这样做可能会导致类型不正确以及 SDK 中其他意外或未定义的行为。
const client = new Anthropic();
const message = await client.messages.create(
{
max_tokens: 1024,
messages: [{ role: "user", content: "Hello, Claude" }],
model: "claude-opus-4-8"
},
{ headers: { "anthropic-version": "My-Custom-Value" } }
);fetch() 返回的"原始" Response 可以通过所有方法返回的 APIPromise 类型上的 .asResponse() 方法访问。
此方法在收到成功响应的标头后立即返回,并且不会消耗响应正文,因此您可以自由编写自定义解析或流式传输逻辑。
您还可以使用 .withResponse() 方法获取原始 Response 以及解析后的数据。
与 .asResponse() 不同,此方法会消耗正文,并在解析完成后返回。
const client = new Anthropic();
const response = await client.messages
.create({
max_tokens: 1024,
messages: [{ role: "user", content: "Hello, Claude" }],
model: "claude-opus-4-8"
})
.asResponse();
console.log(response.headers.get("X-My-Header"));
console.log(response.statusText); // access the underlying Response object
const { data: message, response: raw } = await client.messages
.create({
max_tokens: 1024,
messages: [{ role: "user", content: "Hello, Claude" }],
model: "claude-opus-4-8"
})
.withResponse();
console.log(raw.headers.get("X-My-Header"));
console.log(message.content);所有日志消息仅用于调试。日志消息的格式和内容可能会在不同版本之间发生变化。
日志级别可以通过两种方式配置:
ANTHROPIC_LOG 环境变量logLevel 客户端选项(如果设置,则覆盖环境变量)const client = new Anthropic({
logLevel: "debug" // Show all log messages
});可用的日志级别,从最详细到最简略:
'debug' - 显示调试消息、信息、警告和错误'info' - 显示信息消息、警告和错误'warn' - 显示警告和错误(默认)'error' - 仅显示错误'off' - 禁用所有日志记录在 'debug' 级别,所有 HTTP 请求和响应都会被记录,包括标头和正文。
某些与身份验证相关的标头会被隐去,但请求和响应正文中的敏感数据可能仍然可见。
默认情况下,此库记录到 globalThis.console。您也可以提供自定义日志记录器。
支持大多数日志记录库,包括 pino、winston、bunyan、consola、signale 和 @std/log。如果您的日志记录器无法正常工作,请提交 issue。
提供自定义日志记录器时,logLevel 选项仍然控制发出哪些消息,低于配置级别的消息不会发送到您的日志记录器。
import pino from "pino";
const logger = pino();
const client = new Anthropic({
logger: logger.child({ name: "Anthropic" }),
logLevel: "debug" // Send all messages to pino, allowing it to filter
});此库的类型定义旨在方便访问已记录的 API。如果您需要访问未记录的端点、参数或响应属性,仍然可以使用该库。
要向未记录的端点发出请求,您可以使用 client.get、client.post 和其他 HTTP 动词。
发出这些请求时,将遵循客户端上的选项,例如重试。
await client.post("/some/path", {
body: { some_prop: "foo" },
query: { some_query_arg: "bar" }
});要使用未记录的参数发出请求,您可以在未记录的参数上使用 // @ts-expect-error。此库不会在运行时验证请求是否与类型匹配,因此您发送的任何额外值都将按原样发送。
client.messages.create({
// ...
// @ts-expect-error baz is not yet public
baz: "undocumented option"
});对于使用 GET 动词的请求,任何额外参数都将放在查询字符串中,所有其他请求将在正文中发送额外参数。
如果您想显式发送额外参数,可以使用 query、body 和 headers 请求选项。
要访问未记录的响应属性,您可以在响应对象上使用 // @ts-expect-error,或将响应对象转换为所需的类型。与请求参数一样,SDK 不会验证或剥离 API 响应中的额外属性。
默认情况下,此库期望定义了全局 fetch 函数。
如果您想使用不同的 fetch 函数,可以对全局进行 polyfill:
import fetch from "my-fetch";
globalThis.fetch = fetch;或将其传递给客户端:
import fetch from "my-fetch";
const client = new Anthropic({ fetch });如果您想设置自定义 fetch 选项而不覆盖 fetch 函数,可以在创建客户端或发出请求时提供 fetchOptions 对象。(请求特定的选项会覆盖客户端选项。)
const client = new Anthropic({
fetchOptions: {
// `RequestInit` 选项
}
});要修改代理行为,您可以提供自定义 fetchOptions,为请求添加特定于运行时的代理选项:
Beta 功能在正式发布之前提供,以获取早期反馈并测试新功能。您可以在使用 Claude 构建概述中查看 Claude 所有功能和工具的可用性。
您可以通过客户端的 beta 属性访问大多数 beta API 功能。要启用特定的 beta 功能,您需要在创建消息时将相应的 beta 标头添加到 betas 字段。
例如,要使用 Files API:
const client = new Anthropic();
const response = await client.beta.messages.create({
model: "claude-opus-4-8",
max_tokens: 1024,
messages: [
{
role: "user",
content: [
{ type: "text", text: "Please summarize this document for me." },
{
type: "document",
source: {
type: "file",
file_id: "file_abc123"
}
}
]
}
],
betas: ["files-api-2025-04-14"]
});有关包含代码示例的详细平台设置指南,请参阅:
TypeScript SDK 支持以下平台:
npm install @anthropic-ai/bedrock-sdk:提供 AnthropicBedrockMantle 客户端,以及用于 bedrock-runtime 路径的 AnthropicBedrocknpm install @anthropic-ai/vertex-sdk:提供 AnthropicVertex 客户端npm install @anthropic-ai/foundry-sdk:提供 AnthropicFoundry 客户端npm install @anthropic-ai/aws-sdk:提供 AnthropicAws 客户端。将 workspaceId 传递给构造函数或设置 ANTHROPIC_AWS_WORKSPACE_ID 环境变量。目前处于 beta 阶段。新项目请使用 AnthropicBedrockMantle;AnthropicBedrock 保留用于使用 Bedrock InvokeModel API 的现有应用程序。
此包通常遵循 SemVer 约定,但某些向后不兼容的更改可能会作为次要版本发布:
我们非常重视向后兼容性,以确保您可以依赖顺畅的升级体验。
请参阅 GitHub 仓库获取常见问题解答、问题和社区支持。
Was this page helpful?