在小程序中调用
微信小程序可以通过 wx.cloud.extend.AI 调用云开发 Agent,支持流式输出。
前置条件
- 小程序基础库 3.7.1+
- 已开通云开发环境
- 已创建 Agent
初始化
// app.js
App({
onLaunch() {
wx.cloud.init({
env: 'your-env-id',
});
}
});
基础调用
function generateId() {
const timestamp = Date.now().toString().slice(-4);
const random = Math.floor(Math.random() * 10000).toString().padStart(4, '0');
return timestamp + random;
}
async function sendMessage(message) {
const res = await wx.cloud.extend.AI.bot.sendMessage({
data: {
// botId 必填,标识调用的 Agent
botId: 'your-agent-id',
// 入参结构参考前后端通信协议:
// https://docs.cloudbase.net/ai/agent/http-agent-protocol
threadId: 'thread_id_' + generateId(),
runId: 'run_id_' + generateId(),
messages: [
{ id: String(Date.now()), role: 'user', content: message }
],
tools: [],
context: [],
state: {},
forwardedProps: {},
}
});
// 流式接收响应
let response = '';
for await (const event of res.eventStream) {
// 需要手动解析 event.data
const data = JSON.parse(event.data);
// 根据事件类型输出,响应事件参考文档:
// https://docs.cloudbase.net/ai/agent/http-agent-protocol#%E5%93%8D%E5%BA%94%E4%BA%8B%E4%BB%B6
switch (data.type) {
case 'TEXT_MESSAGE_CONTENT':
response += data.delta;
console.log(data.delta); // 实时输出
break;
case 'RUN_ERROR':
console.error('运行出错:', data.message);
break;
case 'RUN_FINISHED':
// 运行结束
break;
}
}
return response;
}
sendMessage('你好');
完整示例
// pages/chat/chat.js
function generateId() {
const timestamp = Date.now().toString().slice(-4);
const random = Math.floor(Math.random() * 10000).toString().padStart(4, '0');
return timestamp + random;
}
Page({
data: {
messages: [],
inputValue: '',
loading: false,
},
onInput(e) {
this.setData({ inputValue: e.detail.value });
},
async sendMessage() {
const { inputValue, messages } = this.data;
if (!inputValue.trim() || this.data.loading) return;
this.setData({
messages: [...messages, { role: 'user', content: inputValue }],
inputValue: '',
loading: true,
});
try {
const res = await wx.cloud.extend.AI.bot.sendMessage({
data: {
botId: 'your-agent-id',
threadId: 'thread_id_' + generateId(),
runId: 'run_id_' + generateId(),
messages: [
{ id: String(Date.now()), role: 'user', content: inputValue }
],
tools: [],
context: [],
state: {},
forwardedProps: {},
}
});
// 添加空的助手消息
this.setData({
messages: [...this.data.messages, { role: 'assistant', content: '' }],
});
// 流式接收响应
let fullText = '';
for await (const event of res.eventStream) {
const data = JSON.parse(event.data);
if (data.type === 'TEXT_MESSAGE_CONTENT') {
fullText += data.delta;
const updatedMessages = [...this.data.messages];
updatedMessages[updatedMessages.length - 1].content = fullText;
this.setData({ messages: updatedMessages });
}
}
} catch (error) {
console.error('发送消息失败:', error);
wx.showToast({ title: '发送失败', icon: 'none' });
} finally {
this.setData({ loading: false });
}
},
});