Bootstrap

Wechaty + 讯飞星火GPT打造微信机器人

ChatGPT 已经火了一阵了,相信使用ChatGPT还是能够给大家的工作解决一些问题的。如果能直接创建一个微信机器人,辅助自己发消息岂不更爽。今天就将自己实践的教程分享给大家,我们使用wechaty + 讯飞星火GPT来完成这个微信机器人。

在开始之前,先了解一下wechaty,Wechaty 是一款用于构建聊天机器人的开源软件应用程序。它是一种现代会话式 RPA SDK,聊天机器人制造商可以使用它通过几行代码创建机器人,算是目前最方便开发的微信机器人SDK。

Wechaty项目发起比较早了,最快开始通过Hook 网页版微信达到机器人效果。由于18年开始,微信停止了网页版的微信,Wechaty开始拓展Puppet,通过统一开发者接口方便开发,拓展不同Puppet也就是不同代理框架实现微信通信的组合。
在这里插入图片描述

环境准备


node环境 (v16版本以上)

wechaty

**qrcode-terminal(在控制台显示二维码)**

wechaty-puppet-padlocal (ipad协议版)

1.从 github 上 clone 项目

为了方便开发,我们直接使用wechaty-puppet-padlocal 提供的Demo 进行开发。

git clone [email protected]:padlocal/wechaty-puppet-padlocal-demo.git

2.安装项目依赖

cd wechaty-puppet-padlocal-demo
npm --registry https://registry.npm.taobao.org install

这里会自动将puppet-padlocal需要的模块安装

3.VSCode 打开工程,配置Token

由于PadLocal并不免费,所以我们需要取官网(http://pad-local.com/),申请免费的使用token.
在这里插入图片描述

配置好之后,我们先运行一下,看一下基础接口功能能否跑起来
在这里插入图片描述

此时用自己想做机器人的微信号扫码,登录到ipad上,此时就绑定成了机器人。

4.消息发送例子

demo里默认实现了dingdong小Demo,对着机器人微信发送ding,则受到自动回复“dong”,后面我们接入GPT对话,也从这块入手。
在这里插入图片描述
基础小Demo dingdong

5.注册讯飞星火ChatGPT,获得Api token

当前讯飞星火GPT个人账号可以免费领取
在这里插入图片描述

6.开发讯飞GPT消息功能

配置好讯飞大模型的API Key及token

const sendMsg = async (inputVal:string, callback: (data: any) => void) => {
  // 获取请求地址
  let myUrl = await authenticate();

  let socket = new WebSocket(String(myUrl));

  // 监听websocket的各阶段事件 并做相应处理
  socket.addEventListener('open', (event) => {
      console.log('开启连接!!', event);
      // 发送消息
      let params = {
          "header": {
              "app_id": requestObj.APPID,
              "uid": "zhushou"
          },
          "parameter": {
              "chat": {
                  "domain": "general",
                  "temperature": 0.5,
                  "max_tokens": 1024,
              }
          },
          "payload": {
              "message": {
                  // 如果想获取结合上下文的回答,需要开发者每次将历史问答信息一起传给服务端,如下示例
                  // 注意:text里面的所有content内容加一起的tokens需要控制在8192以内,开发者如有较长对话需求,需要适当裁剪历史信息
                  "text": [
                      { "role": "user", "content": "你是谁" }, //# 用户的历史问题
                      { "role": "assistant", "content": "我是AI助手" },  //# AI的历史回答结果
                      // ....... 省略的历史对话
                      { "role": "user", "content": inputVal },  //# 最新的一条问题,如无需上下文,可只传最新一条问题
                  ]
              }
          }
      };
      requestObj.sparkResult = ''
      console.log("发送消息");
      socket.send(JSON.stringify(params))
  })
  socket.addEventListener('message', (event) => {
      let data = JSON.parse(String(event.data))
      console.log('收到消息!!',data);
      requestObj.sparkResult += data.payload.choices.text[0].content
      if (data.header.code !== 0) {
          console.log("出错了", data.header.code, ":", data.header.message);
          // 出错了"手动关闭连接"
          socket.close()
      }
      if (data.header.code === 0) {
          // 对话已经完成
          if (data.payload.choices.text && data.header.status === 2) {
              requestObj.sparkResult += data.payload.choices.text[0].content;
              setTimeout(() => {
                  // "对话完成,手动关闭连接"
                  socket.close()
              }, 1000)
          }
      }
    //   console.log(requestObj.sparkResult);
  })

    socket.addEventListener('close', (event) => {
        console.log('连接关闭!!', event);
        // 对话完成后socket会关闭,将聊天记录换行处理
        // console.log(requestObj.sparkResult);
        callback(requestObj.sparkResult);
    })

    socket.addEventListener('error', (event) => {
        console.log('连接发送错误!!', event);
    })

}

7.将sendMsg函数导出给PadLocal使用

改造dingdongBot函数

export async function dingDongBot(message: Message) {
    if (message.to()?.self() && message.type() == PUPPET.types.Message.Text) {
      await sendMsg(message.text(), (data:string) => {
         message.talker().say(data);
      });
    }
 }

8.重新启动PadLocal服务,登录微信即可完成对话

wechaty的整体设计,还是比较适合开发者使用的,
在这里插入图片描述

如何上面看到在服务终端可以看到GPT自动回复的内容。wechaty的整体设计,还是比方便开发者调用的,

想体验的朋友,加Araon的微信好友,即可与我创建的微信机器人完成对话。

关注公众号《子云之风》,回复“机器人”即可领取Demo源码,日常分享更多小白可以体验学习的黑科技。

;