基于科大讯飞「星火大模型」browser 版本封装
安装步骤和依赖说明
npm install spark-ai-browser
pnpm add spark-ai-browser
yarn add spark-ai-browser
厂家平台配置: https://console.xfyun.cn/services/bm35
// 代码示例
import { Spark } from 'spark-ai-browser';
interface OptionType {
appId: string; // 配置
apiSecret: string; // 配置
apiKey: string; // 配置
sendType:"step"|"all"; // step 每段消息都会通知更新监听函数, all 请求完毕才会更新监听函数
version: '1.1' | '2.1' | '3.1' | '3.5'; //default: '1.1';
}
const spark = new Spark(option );
// 监听数据响应
spark.watchDataChange((text: string, ResultData:ResultData) => {
// 业务处理
});
// 发送消息
spark.webSocketSend(body as SendBody);
interface SendBody {
uuid?: string; // 可以用来标记发送消息人身份,默认系统随机数
content: string;
// payload 默认配置
// {
// message: {
// text: [
// {
// role: 'user',
// content,
// },
// ],
// },
// }
payload?: {
message: {
text: {
role: string,
content: string,
}[],
},
};
// parameter 默认配置
// {
// chat: {
// domain: this.option.modelDomain,
// temperature: 0.5,
// max_tokens: 1024,
// },
// }
parameter?: {
chat: {
domin: string,
temperature: number,
max_tokens: number,
},
};
}
interface ResultData {
header: {
code: number,
message: string,
sid: string,
status: number,
};
payload: {
choices: {
seq: number,
status: number,
text: {
content: string,
index: number,
role: 'assistant',
}[],
question_type: 'knowledge',
},
};
}
// 我只想获取 socket url 地址,我懒得搞加密那些动作,剩下的事,我自己做!
// OK 满足
const spark = new Spark(option );
spark.getOption().url // socket url 完整地址,接下来就交给你自己了。
1. Fork该仓库
2. 创建一个新的分支 (`git checkout -b feature/awesome-feature`)
3. 提交你的修改 (`git commit -am 'Add some awesome feature'`)
4. 推送到分支 (`git push origin feature/awesome-feature`)
5. 提交一个拉取请求
如果有任何问题或者反馈,可以通过以下方式联系作者:
微信:nianyi778 ( 备注 spark-ai )
使用科大讯飞星火大模型 spark3.5 max 版本时,发现准备工作还是挺多的,去查了一下其他开发者开源方案,都不太符合需求。因此萌发了封装聚合的想法。 so spark-ai-browser 诞生了。 欢迎👏 PR