微信小程序调用文心一言数据模子

打印 上一主题 下一主题

主题 2006|帖子 2006|积分 6018

马上注册,结交更多好友,享用更多功能,让你轻松玩转社区。

您需要 登录 才可以下载或查看,没有账号?立即注册

x
微信小程序调用文心一言数据模子


目录
微信小程序调用文心一言数据模子
1.百度千帆大模子平台介绍
2.调用模子程序实现


1.百度千帆大模子平台介绍

调用:
起首要与数据模子API的所在创建毗连,使用微信自带api-wx.request()实现。
需要鉴权,有两种方式,用于识别身份,因为文心一言数据模子的使用要计费。
这里我们使用access_token方式,需要先向服务器发送一个请求数据的文件,根据其返回的access_token参数重新发送请求完成数据模子的调用。这里的access_token相当于调用数据模子的钥匙。
请求所在:ERNIE-4.0-8K - 千帆大模子平台 | 百度智能云文档 (baidu.com)
如图1-1,箭头与红框位置为各个可调用API接口的数据模子,红框右侧为选中模子的具体信息,包罗请求所在、使用方法等,建议仔细阅读。

图1-1

如图1-2,也可在模子广场寻找符合的模子。

图1-2

所在:百度智能云控制台 (baidu.com)
要想调用模子,还需要在系统重创建应用,如图1-3赤色箭头所指,按流程创建,创建内容自拟,对模子调用没有影响。

图1-3

绿色箭头为创建后的应用,我们在调用模子时要根据模子的API文档将应用的API Key和Secret Key填入用以获取毗连。
各种数据模子的室友计费在如图1-4中红箭头所指的计费管理中查看,token调用为我们每次创建毗连的必须的,按token次数可以得知我们调用了多少次数据模子。

图1-4

2.调用模子程序实现

我在这调用的模子为ERNIT-Tiny-8K,属于文心系列模子中的一种。
如图2-1,创建一个新的页面。

图2-1

加入简单的对话框以及按钮方便后续测试使用,如图2-2。

图2-2

轻微修改一下.wxml文件,将用户文本输入绑定存储函数,使获取的回答绑定到界面中:
  1. <button type="primary" style="position: relative; left: 0rpx; top: 396rpx" bind:tap="getAnswer">获取回答</button>
  2. <view style="position: relative; width: 100%; background: #d3d3d3; height: 100px; left: 0rpx; top: 17rpx">
  3.   <input bindinput="getmsg" placeholder="请输入文本" style="width: 750rpx; height: 235rpx; display: block; box-sizing: border-box" auto-focus />
  4.   </view>
  5. <text style="position: relative; left: 0rpx; top: 214rpx">{{wxreply}}</text>
复制代码
来到.js文件预备代码:
  1. data: {
  2.     inputmsg:'',//存放用户输入内容
  3.     wxreply:'',//存放语言模型返回内容
  4.     wenxin_acc:''//用于存储语言模型的access_token
  5. },
  6. onLoad(options) {
  7. this.getwenxin()//与文心模型建立联系,获取access_token
  8.     this.setData({
  9.       wxreply:'泥嚎啊,这里是回答内容'
  10.     })
  11.   },
  12. getmsg(msg){//输入绑定函数,把输入数据存储到getinput中
  13.     this.setData({
  14.       getinput:msg.detail.value
  15.     })
  16.     console.log('输入了'+msg.detail.value);
  17.  },
复制代码
与文心获取接口的函数,该函数绑定在“获取回答”按钮上:
  1. getwenxin(){
  2.     var that = this;
  3.     const wenxin_url = 'https://aip.baidubce.com/oauth/2.0/token?grant_type=client_credentials&client_id=b52gxsglW27RqsvZAwjITYH5&client_secret=G7lUVA0VMkZ7oLNFm0CfQKPMzWk8WSV0';//存放请求API的地址,这里根据官方API文档的提示填入API KEY和Secret Key
  4.     wx.request({
  5.       url: wenxin_url,
  6.       header: {
  7.         'Content-Type': 'application/json'
  8.       },//header根据API文档要求配置
  9.       method: 'POST',//请求方式,这里文档中要求为post
  10.       success:res=>{
  11.         console.log(res),
  12.         that.setData({//①标记--存储access_token
  13.           wenxin_acc:res.data.access_token
  14.         })
  15.       }
  16.     })
  17.   },
复制代码
可见我在成功回调函数上写了console.log(res)用于获取网站返回信息,后序只需触发函数即可获得之,它的意义是获取调用语言模子必须的access_token值。这里标记①先不管。
此时图形化界面如图2-3所示:

图2-3

现在可以点击获取回答试试看能不能与模子所在成功毗连,可见点击后也是成功获取到了,如图2-4:

图2-4

图中赤色箭头所指的内容即我们需要的access_token。则上面代码部门标记①就可以将access_token存储于data当中方便我们后续使用。
接下来可以编写getAnswer()函数用以获取语言模子返回内容了:
  1. getAnswer(){//向文心模型发送数据
  2.     var that = this
  3.     const wenxin_url = 'https://aip.baidubce.com/rpc/2.0/ai_custom/v1/wenxinworkshop/chat/ernie-tiny-8k?access_token=' + this.data.wenxin_acc//刚刚获得的token
  4.     const question = {//向语言模型发送的数据
  5.       "messages": [
  6.         {
  7.           "role": "user",
  8.           "content": that.data.inputmsg
  9.         }
  10.       ]
  11.     }
  12.     wx.request({//网络请求,下面是各个参数
  13.       url: wenxin_url,
  14.       method: 'POST',
  15.       data: question,
  16.       header: {'Content-Type': 'application/json'},
  17.       success:res=>{//将返回的数据存入data以便于显示
  18.         console.log(res.data)
  19.         that.setData({
  20.           wxreply:res.data.result
  21.         })
  22.       }
  23.     })
  24.   },
复制代码
现在运行程序试试:

图2-5

没问题,输入文本试试能不能使用语言模子:

图2-6

可见已经可以大概成功调用模子了。
文章性质为本人学习后做的笔记,如有侵权请接洽本人删除。

免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!更多信息从访问主页:qidao123.com:ToB企服之家,中国第一个企服评测及商务社交产业平台。
回复

使用道具 举报

0 个回复

倒序浏览

快速回复

您需要登录后才可以回帖 登录 or 立即注册

本版积分规则

尚未崩坏

论坛元老
这个人很懒什么都没写!
快速回复 返回顶部 返回列表