go-cqhttp调用接口

news/2024/5/3 4:38:20/文章来源:https://www.cnblogs.com/liuzhongkun/p/16704720.html

目录
  • 调用接口
    • 一、 概述
      • 1、 简介
      • 2、 接口
    • 二、 接入权限系统
      • 1、 智能聊天
      • 2、 戳一戳
      • 3、 新成员
    • 三、 调用接口
      • 1、 查找接口
      • 2、 调用接口
      • 3、 接入机器人

调用接口

一、 概述

1、 简介

在我们实现了权限控制功能后,那么我们就在也不用担心机器人话太多,同时,平时又没时间,电脑又不在身边,而无法控制机器人了。那么,我们实现了权限的管理就好说了。然后,又出现一个问题了,我们应该如何利用这个权限系统,来帮助我们管理机器人呢?

这个大家马上就会知晓了,我会从如何控制智能聊天,以及控制戳一戳,再接入一些功能接口。来讲述,如何使用这个权限功能。

2、 接口

其次,我们还需要了解一下,什么是接口呢?

应用程序接口(API,Application Programming Interface)是基于编程语言构建的结构,使开发人员更容易地创建复杂的功能。它们抽象了复杂的代码,并提供一些简单的接口规则直接使用。

举一个例子:想想您的房子、公寓或其他住宅的供电方式,如果您想在您的房子里用电,只要把电器的插头插入插座就可以,而不是直接把它连接到电线上——这样做非常低效,而且对于不是电工的人会是困难和危险的。

同时,可以根据这张图来理解API的功能,其就是可以给客户端来提供数据的。

我们访问一些特定的API就可以得到我们想要的数据,这有一些较为好用的API提供方:

下面,我将来告诉大家,API的使用方法

二、 接入权限系统

在调用API之前,我们先来学习一下,如何给戳一戳和智能聊天接入我们的权限管理系统,私聊的权限这里就不做展示了。大家可以根据这几次的文章,开发一个私聊的权限。

1、 智能聊天

我是这样设置的,为了防止机器人回的消息过多,只有艾特机器人的消息,它才会回,当然这是基于权限的基础上了,那么,如何接入呢?

请大家看代码:

if _.get("message_type") == "group" and "[CQ:at,qq=2786631176]" in _["raw_message"]:  # 即使用in来判断其是否为艾特机器人的消息# 制作群聊消息db = current_app.config["db"]  session = db.sessiongroup = session.query(Group).filter(db.and_(Group.qqId == _["group_id"], Group.isDetect)).first() # 同时这个群要支持机器人聊天,才会进入下一步if group and group.group2auth.chat:  # 如果允许聊天的话,就在群内开启聊天功能,这个是基于if的权限管理系统asyncio.run(GroupChatMes.handle_group(_))# GroupChatMes.handle_group的内容
async def handle_group(resp):message = resp["raw_message"].replace("[CQ:at,qq=2786631176]", "")  # 获取发送过来的消息gid = resp["group_id"]  # 获取发送消息的群号# 处理群聊信息if message.strip() == "":await send(gid, "艾特我干啥?又不发消息,一巴掌呼死你![CQ:face,id=86][CQ:face,id=12]", "group")else:# 调用接口,来获取回复,同时这里使用了异步请求async with httpx.AsyncClient() as client:params = {"key": "free","appid": 0,"msg": message,}resp = await client.get("http://api.qingyunke.com/api.php", params=params)_ = resp.json()ret = _.get("content", "获取回复失败")await send(gid, ret, "group")  # 发送群组消息

2、 戳一戳

戳一戳,就回复,这个功能是有点烦人的,如果是讨厌这个机器人的话,那当然就需要进行权限的控制啦!废话不多说,直接上代码

if _.get("sub_type") == "poke":# 如果事件类型为戳一戳asyncio.run(GroupAndPri.click_event(_))# GroupAndPri.click_event的内容
async def click_event(resp):uid = resp["user_id"]tid = resp["target_id"]if str(tid) != "3500515050" and str(tid) != "2786631176":  # 如果不是这两个账号的戳一戳,则不管returntry:gid = resp["group_id"]db = current_app.config["db"]session = db.sessiongroup = session.query(Group).filter(db.and_(Group.qqId == gid, Group.isDetect)).first()  # 同时这个需要被检测到,如果为群戳戳的话except KeyError as e:gid = Nonegroup = None# 处理戳一戳的消息info = choice(current_app.config.get("CLICK_MES"))  # 获取戳一戳需要回复的的信息try:info = info % uidexcept Exception as e:if gid:  # 说明其为群戳戳info = f"[CQ:at,qq={uid}]" + infoif gid is None:  # 其为私聊信息await send(uid, info, "private")  # 发送信息,这个函数在上一篇文章中实现过elif gid and group.group2auth.click:  # 如果允许发送戳一戳的内容的话,就发送,反之,什么都不做,进行权限的判断await send(gid, info, "group")

3、 新成员

对于新成员的欢迎也是如此,也需要进行权限的管理

if _.get("notice_type") == "group_increase":# 有新成员加入db = current_app.config["db"]session = db.sessiongroup = session.query(Group).filter(db.and_(Group.qqId == _["group_id"], Group.isDetect)).first()if group and group.group2auth.welcome:  # 开启欢迎的功能的话,就继续,否则返回asyncio.run(GroupChatMes.group_increase(_))  # 发送欢迎语
# GroupChatMes.group_increase的内容
async def group_increase(resp):uid = resp["user_id"]  # 获取加入者的qqgid = resp["group_id"]  # 获取群号# 处理有新成员加入的情况welcome_group = current_app.config.get("WELCOME_MES")  # 从配置文件中获取欢迎的语句msg = welcome_group.get(str(gid),welcome_group["default"]) % uid  # welcome_group的键是qq群号,值是欢迎语await send(gid, msg, "group")  # 发送信息

三、 调用接口

1、 查找接口

上面说了那么多,还没说到今天的重点,今天的重点就是实现机器人的主要功能,给群聊增加一些小功能,这些小功能的实现,是通过调用接口,或者自己编程实现的?那么,对比这两者,你更倾向于哪一种呢?我想是调用被人封装好的接口吧,简单又方便,相对来说也较为稳定。

这里推荐一些提供质量较好的接口的网站吧!

  • https://www.yuanxiapi.cn/
  • http://www.alapi.cn/api/list/
  • https://api.vvhan.com/
  • http://bjb.yunwj.top/php/API/html.html
  • ...

如果还有其他较好用的接口,可以在评论区下方留言一起分享哦!

好,接口在哪找我们知道了!那怎么用呢?

2、 调用接口

其实调用方法非常简单,就是使用网络请求工具,对这个地址发送请求,我们就可以得到这个接口的内容了!

# 比如,我对http://bjb.yunwj.top/php/tp/lj.php这个接口发送请求
#!/usr/bin/python3
# -*- coding: UTF-8 -*-
__author__ = "A.L.Kun"
__file__ = "handle.py"
__time__ = "2022/9/9 19:53"import httpx
import reresp = httpx.get("http://bjb.yunwj.top/php/tp/lj.php")
data = re.findall('"tp":"(?P<url>.*?)"', resp.text)[0]
print(data)

3、 接入机器人

在知道如何调用这个接口后,我们就可以尝试的把这个接入我们的机器人中去了!

首先,我们需要做一个消息分发的功能

    # 群聊小心分发的方式为:if _.get("message_type") == "group":# 获取群命令db = current_app.config["db"]session = db.sessiongroup = session.query(Group).filter(db.and_(Group.qqId == _["group_id"], Group.isDetect)).first()if not group:returnmessage = _.get("raw_message")if message.startswith("/"):  # 如果这个函数是以/开头的话,说明其为命令,可能为管理员命令,也可能是普通命令,进行进一步分判别asyncio.run(Command.command(_, "group", group.group2auth.smallFunction))  # 同时传入这个群是否开启了拓展功能,方便后面的判断async def command(resp, ty, isornot=None):  # 对命令进行分类,如果这个消息是/开头的话,就直接进入到这个函数中,同时/开头的消息,还有管理员信息,故需要进行一个群区分"""对所有命令进行处理:param resp: post的数据:param ty: 消息来自哪里:param isornot: 当为群消息时,要传入是否支持拓展功能:return:"""uid = resp["sender"]["user_id"]  # 获取发信息的好友qq号message = resp["raw_message"]  # 获取发送过来的消息if ty == "group":gid = resp["group_id"]  # 获取群号else:gid = Noneif message.startswith("/admin:"):"""管理系统的命令"""if str(uid) in current_app.config["SUPER_USER"] and ty == "private":await Command.super_command(uid, message)elif ty == "group" and resp["sender"]["role"] in ["owner", "admin"]:  # 判断运行这个命令的是否为群管理员# 说明这个是群管理员的修改await Command.admin_command(uid, gid, message)else:await Sender.send(uid if ty == "private" else gid, "权限不足!", ty)else:if isornot or ty == "private":  # 查看是否开启这个功能,是私聊消息,或者开启了拓展功能"""管理拓展功能的命令"""await Command.com_command(uid if gid is None else gid, message, ty, resp)else:await Sender.send(resp["group_id"], "本群没有开启拓展功能哦!请联系管理员开启这个功能!", "group")

进行分发完后,我们就需要对命令进行解析了:

async def com_command(id, message, ty, resp):  # 处理一般的命令"""id : uid / gidmessge : 命令消息ty: 这个消息是从哪里来的resp: 同时把响应的结果也传入"""uid = resp["sender"]["user_id"]base = "[CQ:at,qq=" + str(uid) + "]" if ty == 'group' else ""command = re.findall(r"/(.*)", message.split()[0])[0]  # 先获取一个类似函数的命令,作为启动if command == "bing":msg = await ConnectApi.get_bing()await Sender.send(id, msg, ty)elif command == "天气":if len(message.split()) != 2:await Sender.send(id, "输入格式错误,请根据帮助文档输入!", ty)returncity = message.split()[1]msg = await ConnectApi.weather(city)await Sender.send(id, msg, ty)elif command == "send":  # 提建议给开发者if len(message.split()) < 2:await Sender.send(id, "输入格式错误,请根据帮助文档输入!", ty)returncontent = "\n".join(message.split()[1:]) + f"\n——{uid}"await Sender.send(current_app.config["ADMIN"], content, "private")await Sender.send(id, base + "收到,谢谢您的建议![CQ:face,id=63][CQ:face,id=63][CQ:face,id=63]", ty)elif command == "简报": # 获取每日简报msg = await ConnectApi.brief()await Sender.send(id, msg, ty)# 实现的函数的代码
class ConnectApi:"""连接接口,创建拓展功能"""@staticmethodasync def get_bing():"""获取bing的每日一图:return:"""return "[CQ:image,file=https://www.yuanxiapi.cn/api/bing/,cache=0]"  # 这个网站就是一个接口@staticmethodasync def weather(city):"""天气数据获取"""async with httpx.AsyncClient(headers={"user-agent": UserAgent().random,}) as client:resp = await client.get("https://api.wpbom.com/api/weather.php?city=%s" % city)  # 向接口中传入城市信息data = resp.json()  # 获取返回的JSON数据try:if data["status"] == 1000:# 获取成功,对数据进行解析city = data["data"]["city"]wea = data["data"]["forecast"][0]high = re.findall(r".*?(?P<tem>\d.*)", wea["high"])[0]low = re.findall(r".*?(?P<tem>\d.*)", wea["low"])[0]type_ = wea["type"]ganmao = data["data"]["ganmao"]ret = f"{city}今日天气{type_}:\n{low}~{high}\n温馨提示:{ganmao}"else:raise ValueErrorexcept Exception as e:# 接口获取失败ret = f"{city}天气数据获取失败!"return ret@staticmethodasync def brief():# 获取每日简报async with httpx.AsyncClient() as client:resp = await client.get("http://bjb.yunwj.top/php/tp/lj.php")  # 同时,对于异步任务,记得要挂起url = re.findall('"tp":"(?P<url>.*?)"', resp.text)[0]return f"[CQ:image,file={url},cache=0]"  # 使用cq码发送我们的图片信息

好了,今天的文章就到这里结束了,不知道您学到了多少呢?代码,在我完成全部的功能之后,会在GitHub开源出来,所以大家不用担心代码的问题。现在只需要理解这些功能的实现原理。当然,能根据自己的理解,写一个属于自己的机器人就更好了!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.luyixian.cn/news_show_9628.aspx

如若内容造成侵权/违法违规/事实不符,请联系dt猫网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

openSmile 在 Linux 下的安装教程与使用示例

目录openSMILE 工具简介Linux 上的安装步骤使用示例后续openSMILE 工具简介 一款以命令行形式运行的工具&#xff0c;通过配置config文件&#xff0c;主要用于音频特征的提取。官网&#xff1a;https://www.audeering.com/research/opensmile/ &#xff08;当前是3.0版本&…

Oracle中的用户和表空间

文章目录Oracle中的用户和表空间一、用户和表空间简介二、用户1、系统用户登录1.1、数据库在本机时1.2、数据库在远程时1.3、案例2、查看登录用户2.1、命令2.2、案例3、解锁与锁定用户3.1、命令3.2、案例4、使用scott用户登录4.1、命令4.2、案例三、表空间1、表空间数据字典2、…

解决从PDF复制文字后乱码问题

背景 需要从PDF复制文字出来做笔记&#xff0c;可是谁知道PDF通过adobe打开后复制出来后是乱码&#xff0c;如下图所示&#xff1a; 解决 尝试过安装字体&#xff0c;可惜没卵用。 方法1-CAJViewer打开 用该软件打开后复制&#xff0c;可以完美复制&#xff0c;但是有个小问题…

Fastformer: Additive Attention Can Be All You Need

创新点:本文根据transformer模型进行改进,提出了一个高效的模型,模型复杂度呈线性。 主要改进了注意力机制,出发点在于降低了注意力矩阵的重要程度,该方法采用一个(1*T)一维向量替换了原始T*T大小的注意力矩阵。注意力结构图: 在这里,输入同样通过不同的线性映射得到Q…

Vue23全面知识总结七(2)

感兴趣的朋友可以去我的语雀平台进行查看更多的知识。 https://www.yuque.com/ambition-bcpii/muziteng 7.8 路由的props配置 props作用&#xff1a;让路由组件更方便的收到参数 {name:detail,path:detail/:id,component:Detail,//第一种写法&#xff1a;props值为对象&…

Java内存模型:创建对象在堆区如何分配内存

一、Heap堆区 Heap堆是JVM所管理的内存中最大的一块区域&#xff0c;被所有线程共享的一块内存区域。堆区中存放对象实例和数组&#xff0c;“几乎”所有的对象实例以及数组都在这里分配内存。 新生代、老年代 二、创建对象的内存分配 初始创建对象会在新生代的Eden区生成&…

行为型设计模式之策略模式

行为型设计模式之策略模式策略模式应用场景优缺点主要角色策略模式的基本使用创建抽象策略角色创建具体策略角色创建上下文角色客户端执行策略模式实现支付方式的选择创建抽象策略角色创建具体策略角色创建上下文角色客户端执行策略模式 策略模式&#xff08;Strategy Pattern)…

线程安全集合:CopyOnWriteArrayList源码分析

目录 一、基本思想 二、源码分析 add()方法 set()方法 remove()方法 get()方法 三、小结 一、基本思想 首先CopyOnWrite 简称 COW &#xff0c;是一种用于对集合并发访问的优化策略。基本思想是&#xff1a;当我们往一个集合容器中写入元素时&#xff08;比如添加…

C++左值右值、左值引用右值引用、移动语义move

目录 1.什么是左值、右值 2.什么是左值引用&、右值引用&& 2.1左值引用& 2.2右值引用&& 2.3对左右值引用本质的讨论 2.3.1右值引用有办法指向左值吗&#xff1f; 2.3.2左值引用、右值引用本身是左值还是右值&#xff1f; 2.4 右值引用使用场景…

51单片机学习:静态数码管实验

实验名称&#xff1a;静态数码管实验 接线说明&#xff1a; 实验现象&#xff1a;下载程序后“数码管模块”最左边数码管显示数字0 注意事项&#xff1a; ***************************…

神经体液调节网络,神经网络能干嘛

神经网络的发展趋势如何&#xff1f; 神经网络的云集成模式还不是很成熟&#xff0c;应该有发展潜力&#xff0c;但神经网络有自己的硬伤&#xff0c;不知道能够达到怎样的效果&#xff0c;所以决策支持系统中并不是很热门&#xff0c;但是神经网络无视过程的优点也是无可替代…

CSDN编程竞赛-第六期(上)

CSDN编程竞赛报名地址&#xff1a;https://edu.csdn.net/contest/detail/16 努力是为了让自己不平庸&#xff1a; 前言/背景 四道题都是相关数组的&#xff0c;思路很好想&#xff0c;但是需要熟练使用&#xff0c;不能有小错误。 参赛流程 活动时间&#xff1a;9月8日-21日&a…

Python机器视觉--OpenCV进阶(核心)--图像直方图与掩膜直方图与直方图均衡化

1.图像直方图 1.1 图像直方图的基本概念 在统计学中&#xff0c;直方图是一种对数据分布情况的图形表示&#xff0c;是一种二维统计图表. 图像直方图是用一表示数字图像中亮度分布的直方图&#xff0c;标绘了图像中每个亮度值的像素数。可以借助观察该直方图了解需要如何调整…

记录一次关于Rank()排序函数问题

先来看应用场景吧 就是页面上有个top按钮 根据不同的top 进行筛选 比如我选择top5 那么在下方当前大区的销售额降序筛选出来最高的前五个销售员or客户这种场景 &#x1f496; 问题 问题1&#xff1a;为什么我的这个rank排序函数 这个华南大区 不是从1开始的呢 其他大区都是正…

java毕业设计选题系统ssm实现的商城系统(电商购物项目)

&#x1f345;文末获取联系&#x1f345; 一、项目介绍 《ssm实现的商城系统》该项目采用技术&#xff1a;springspringMVCmybaitsEasyUIjQueryAjax等相关技术&#xff0c;项目含有源码、文档、配套开发软件、软件安装教程、项目发布教程等 1.1 课题背景、目的及意义 当今社…

java 同学聚会AA制共享账单系统springboot 小程序022

本系统在一般同学会小程序的基础上增加了首页推送最新信息的功能方便用户快速浏览&#xff0c;是一个高效的、动态的、交互友好的同学会小程序。 用户在首页上会看到各类模块的推送内容&#xff0c;可以以最直接的方式获取信息&#xff0c;注册登陆后&#xff0c;可以对应经费信…

Unity基础笔记(5)—— Unity渲染基础与动画系统

Unity渲染基础与动画系统 Unity渲染基础 一、摄像机 1. 摄像机概念和现实中的摄像机很接近,Unity 中 Camera 组件负责将游戏画面拍摄然后投放到画面上 Camera 拍摄到的画面决定了 Game 面板的画面 创建场景的时候,Unity 会默认创建一个摄像机,所以我们点击 Game 面板才有画面…

【算法刷题】链表篇-链表的回文结构

文章目录题目要求方法1&#xff1a;思路代码方法2代码题目要求 链接&#xff1a;链表的回文结构_牛客题霸_牛客网 (nowcoder.com) 1 -> 2 -> 3 -> 2 -> 1 1 -> 2 -> 2 -> 1 上面两个是回文结构 方法1&#xff1a;思路 1.遍历链表&#xff0c;把结点对应的…

网络安全基础——对称加密算法和非对称加密算法(+CA数字证书)

目录 一、数据传输时的安全特性 二、对称加密算法&#xff1a; 三、非对称加密算法 四、对称加密和非对称加密 — 融合算法&#xff1a; 五、CA数字证书&#xff1a; 一、数据传输时的安全特性 ———————————————————————————————————…

分布式进化算法

1 多解优化问题 多解优化问题是指一类具有多个最优解的复杂优化问题。多峰优化问题和多目标优化问题都是两类典型的多解优化问题&#xff0c;它们之前的统一关系&#xff0c;即都具有多个最优解。多峰优化问题要求算法找到多个具有相同适应度值得最优解&#xff0c;多目标优化问…