开始使用 Qwen Code 扩展
本指南将带你创建第一个 Qwen Code 扩展。你将学习如何设置新扩展、通过 MCP 服务器添加自定义工具、创建自定义命令,以及使用 QWEN.md 文件为模型提供上下文。
先决条件
开始之前,请确保你已安装 Qwen Code,并对 Node.js 和 TypeScript 有基本了解。
步骤 1:创建新扩展
最简单的开始方式是使用内置模板之一。我们将以 mcp-server 示例作为基础。
运行以下命令创建一个名为 my-first-extension 的新目录,并包含模板文件:
qwen extensions new my-first-extension mcp-server这将创建一个具有以下结构的新目录:
my-first-extension/
├── example.ts
├── qwen-extension.json
├── package.json
└── tsconfig.json步骤 2:了解扩展文件
让我们来看看新扩展中的关键文件。
qwen-extension.json
这是你的扩展的清单文件。它告诉 Qwen Code 如何加载和使用你的扩展。
{
"name": "my-first-extension",
"version": "1.0.0",
"mcpServers": {
"nodeServer": {
"command": "node",
"args": ["${extensionPath}${/}dist${/}example.js"],
"cwd": "${extensionPath}"
}
}
}name:你的扩展的唯一名称。version:你的扩展的版本。mcpServers:此部分定义了一个或多个模型上下文协议(MCP)服务器。MCP 服务器是你为模型添加新工具的方式。command、args、cwd:这些字段指定了如何启动你的服务器。注意使用了${extensionPath}变量,Qwen Code 会将其替换为你的扩展安装目录的绝对路径。这使得你的扩展无论安装在何处都能正常工作。
example.ts
该文件包含你的 MCP 服务器的源代码。这是一个简单的 Node.js 服务器,使用了 @modelcontextprotocol/sdk。
/**
* @license
* Copyright 2025 Google LLC
* SPDX-License-Identifier: Apache-2.0
*/
import { McpServer } from '@modelcontextprotocol/sdk/server/mcp.js';
import { StdioServerTransport } from '@modelcontextprotocol/sdk/server/stdio.js';
import { z } from 'zod';
const server = new McpServer({
name: 'prompt-server',
version: '1.0.0',
});
// 注册一个名为 'fetch_posts' 的新工具
server.registerTool(
'fetch_posts',
{
description: '从公共 API 获取文章列表。',
inputSchema: z.object({}).shape,
},
async () => {
const apiResponse = await fetch(
'https://jsonplaceholder.typicode.com/posts',
);
const posts = await apiResponse.json();
const response = { posts: posts.slice(0, 5) };
return {
content: [
{
type: 'text',
text: JSON.stringify(response),
},
],
};
},
);
// ...(为简洁起见,提示注册部分已省略)
const transport = new StdioServerTransport();
await server.connect(transport);此服务器定义了一个名为 fetch_posts 的工具,用于从公共 API 获取数据。
package.json 和 tsconfig.json
这些是 TypeScript 项目的标准配置文件。package.json 文件定义了依赖项和 build 脚本,而 tsconfig.json 配置了 TypeScript 编译器。
步骤 3:构建并链接你的扩展
在使用该扩展之前,你需要编译 TypeScript 代码,并将扩展链接到你的 Qwen Code 安装目录以进行本地开发。
-
安装依赖项:
cd my-first-extension npm install -
构建服务端代码:
npm run build这会将
example.ts编译为dist/example.js,该文件在你的qwen-extension.json中被引用。 -
链接扩展:
link命令会在 Qwen Code 的扩展目录与你的开发目录之间创建一个符号链接。这意味着你所做的任何更改都会立即生效,而无需重新安装。qwen extensions link .
现在,重启你的 Qwen Code 会话。新的 fetch_posts 工具将会可用。你可以通过提问“fetch posts”来测试它。
步骤 4:添加自定义命令
自定义命令提供了一种为复杂提示创建快捷方式的方法。让我们添加一个在代码中搜索模式的命令。
-
创建
commands目录以及命令组的子目录:mkdir -p commands/fs -
创建一个名为
commands/fs/grep-code.toml的文件:prompt = """ 请总结模式 `{{args}}` 的查找结果。 搜索结果: !{grep -r {{args}} .} """此命令
/fs:grep-code将接受一个参数,使用该参数运行grepshell 命令,并将结果传入提示中进行总结。
保存文件后,重新启动 Qwen Code。现在你可以运行 /fs:grep-code "some pattern" 来使用你的新命令。
步骤 5:添加自定义 QWEN.md
你可以通过在扩展中添加一个 QWEN.md 文件来为模型提供持久的上下文。这对于指导模型如何行为,或提供有关扩展工具的信息非常有用。请注意,对于仅暴露命令和提示的扩展,你可能并不总是需要这个文件。
-
在扩展目录的根目录下创建一个名为
QWEN.md的文件:# 我的第一个扩展说明 你是一位专家级开发者助手。当用户要求你获取文章时,请使用 `fetch_posts` 工具。回答请简洁明了。 -
更新你的
qwen-extension.json文件,告诉 CLI 加载该文件:{ "name": "my-first-extension", "version": "1.0.0", "contextFileName": "QWEN.md", "mcpServers": { "nodeServer": { "command": "node", "args": ["${extensionPath}${/}dist${/}example.js"], "cwd": "${extensionPath}" } } }
再次重启 CLI。现在,在扩展激活的每个会话中,模型都将拥有来自你的 QWEN.md 文件的上下文。
步骤 6:发布你的扩展
当你对扩展满意后,就可以与他人分享。发布扩展的两种主要方式是通过 Git 仓库或 GitHub Releases。使用公共 Git 仓库是最简单的方法。
有关这两种方法的详细说明,请参阅扩展发布指南。
结论
你已成功创建了一个 Qwen Code 扩展!你学会了如何:
- 从模板引导新扩展。
- 使用 MCP 服务器添加自定义工具。
- 创建便捷的自定义命令。
- 为模型提供持久上下文。
- 链接扩展以进行本地开发。
接下来,你可以探索更多高级功能,并将强大的新能力构建到 Qwen Code 中。