跨境派

跨境派

跨境派,专注跨境行业新闻资讯、跨境电商知识分享!

当前位置:首页 > 跨境学堂 > 调用讯飞火星AI大模型WebAPI

调用讯飞火星AI大模型WebAPI

时间:2024-04-08 12:05:38 来源:网络cs 作者:付梓 栏目:跨境学堂 阅读:

标签: 模型  火星  调用 
阅读本书更多章节>>>>

调用讯飞火星AI大模型

记录一次调用讯飞AI大模型的过程
官方文档
首先,去官网申请资格,获得必要秘钥等
再编写url,该url存在编码要求,具体看官网url编写
具体代码如下:

 getWebsocketUrl() {      return new Promise((resolve, reject) => {        var apiKey = API_KEY        var apiSecret = API_SECRET        var url = 'ws://spark-api.xf-yun.com/v3.1/chat'        var host = location.host        var date = new Date().toGMTString()        var algorithm = 'hmac-sha256'        var headers = 'host date request-line'        var signatureOrigin = `host: ${host}\ndate: ${date}\nGET /v3.1/chat HTTP/1.1`        var signatureSha = CryptoJS.HmacSHA256(signatureOrigin, apiSecret)        var signature = CryptoJS.enc.Base64.stringify(signatureSha)        var authorizationOrigin = `api_key="${apiKey}", algorithm="${algorithm}", headers="${headers}", signature="${signature}"`        var authorization = btoa(authorizationOrigin)        url = `${url}?authorization=${authorization}&date=${date}&host=${host}`        console.log(url)        resolve(url)      })    },

再就是参数,跟官网要求配置相同

 var params = {        header: {          app_id: APPID          // "uid": uid        },        parameter: {          chat: {            // 指定访问的领域,general指向V1.5版本,generalv2指向V2版本,generalv3指向V3版本 。            // 注意:不同的取值对应的url也不一样!            domain: 'generalv3',            // 核采样阈值。用于决定结果随机性,取值越高随机性越强即相同的问题得到的不同答案的可能性越高            temperature: 0.5,            // 模型回答的tokens的最大长度            max_tokens: 1024          }        },        payload: {          message: {            text: this.msgStore          }        }      }

注意要转json
最后是请求函数

async sendRequestToWebSocket(url) {      return new Promise((resolve, reject) => {        const socket = new WebSocket(url)        // 监听WebSocket的open事件        socket.addEventListener('open', () => {          console.log('WebSocket已连接')          // socket.send(JSON.stringify(requestPayload));          socket.send(this.creatParam())        })        // 监听WebSocket的消息事件        socket.addEventListener('message', (event) => {          const serverResponse = JSON.parse(event.data)          //这里状态码1为继续,2为结束,只的是本次请求结束          if (serverResponse.header.code === 0 && serverResponse.payload && serverResponse.header.status != 2) {          } else if (serverResponse.header.code === 0 && serverResponse.payload && serverResponse.header.status === 2)           } else {            reject(new Error(`WebSocket服务端返回错误: ${serverResponse.header.message}`))          }        })        // 监听WebSocket的close和error事件以进行异常处理        socket.addEventListener('close', () => {          console.log('WebSocket已关闭')        }) // 使用远程用户的样式(蓝色气泡)})        socket.addEventListener('error', (error) => {          reject(error)          socket.close()        })      })    },

这个接口返回的数据值得讲一下
在这里插入图片描述
code成功都是0,而最后一次返回数据status为2,第一次为0,中间为1
在这里插入图片描述
在这里插入图片描述
具体其余参数如文档所示,本次并未使用
在这里插入图片描述
最后就是处理返回数据,要注意的是数据是分几次返回的,需要按照一定需求拼接。
一下本次功能实现效果,较为简约
在这里插入图片描述

阅读本书更多章节>>>>

本文链接:https://www.kjpai.cn/xuetang/2024-04-08/155411.html,文章来源:网络cs,作者:付梓,版权归作者所有,如需转载请注明来源和作者,否则将追究法律责任!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容,一经查实,本站将立刻删除。

文章评论