调用企业微信API发送文本,图片,文件消息[通俗易懂]

调用企业微信API发送文本,图片,文件消息[通俗易懂]简单封装一个调用企业微信API程序发送文本,图片,及文件消息。

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE稳定放心使用

1.调用api向企业微信(通过CORPID标识)的自建应用程序(通过Secret, AgentID标识)发送文本、图片或者文件消息;
2.创建实例时传入以下参数:

(1) touser–>str,接收消息者的标识(已在企业微信的通讯录中添加,添加后微信后台会自动分配标识),多个用户使用 “|” 隔开(如”zhdb|zhj|wqq”),所有人(“@all”);
(2) corp_id–>str,企业ID,申请企业微信时获得;
(3) secret, agent_id–>str, 创建企业应用时获得.

3.本实例定义了三种消息格式的发送(text, image, file), 使用实例如下:
chat = CorpWechat(touser, corp_id, secret, agent_id)

# 发送text文本消息
chat.send_message(msg_type='text', contents="Format message str")
# 发送image图片消息(本地图片)
chat.send_message(msg_type='image', file_obj=open(image_path, 'rb'))
# 发送file文件消息(本地文件)
chat.send_message(msg_type='file', file_obj=open(file_path, 'rb'))

另外也经常有这种情况,调用其它图片生成库在线绘制的图形可先存入到二进制缓存文件中,再将该对象作为file_obj参数传入,

例如用发送用matplotlib所生成的图片

import matplotlib.pyplot as plt
import numpy as np

from io import BytesIO

x = np.arange(50)
plt.plot(x, x**2)
buffer = BytesIO()  # 创建缓存文件
plt.savefig(buffer)  # 将生成的图片存入缓存文件
data = buffer.getvalue()  # 读取成可以传入file_obj的数据格式
chat.send_message(msg_type='image', file_obj=data)

再有就是发送调用其它文件生成库生成的文件的话,可先创建临时文件夹,然后保存到该文件夹下,发送时再读取,

例如用reportlab生成PDF文件的发送如下

–>脚本目录下创建temp文件夹;

from reportlab.pdfgen import canvas

pdf_path = 'temp\\test.pdf'
c = canvas.Canvas(pdf_path)
c.drawString(50, 50, "This is a test pdf file!")
c.save()  # 生成文件到本地
chat.send_message(msg_type='file', file_obj=open(pdf_path, 'rb'))

CorpWechat类创建脚本如下:

# -*- coding: utf-8 -*-
import requests
import json

class CorpWechat:
    def __init__(self, touser, corp_id, secret, agent_id):
        self.base_url = "https://qyapi.weixin.qq.com/cgi-bin"
        self.touser = touser
        self.corp_id = corp_id
        self.secret = secret
        self.agent_id = agent_id
        self.token = self._get_token()

    def _get_token(self):
        arg_url = '/gettoken?corpid={}&corpsecret={}'.format(self.corp_id, self.secret)
        url = self.base_url + arg_url
        r = requests.get(url)
        js = json.loads(r.text)
        try:
            return js['access_token']
        except KeyError:  # 成功返回后就会获得'access_token'字段,否则报错KeyError
            raise KeyError("Get access-token failed.")

    def _get_media_id(self, msg_type, file_obj):
        arg_url = "/media/upload?access_token={}&type={}".format(self.token, msg_type)
        url = self.base_url + arg_url
        data = { 
   "media": file_obj}
        r = requests.post(url=url, files=data)
        js = r.json()
        try:
            return js['media_id']
        except KeyError:  # 成功返回后就会获得'media_id'字段,否则报错KeyError
            raise KeyError("Get media_id failed.")

    def _gen_msg(self, msg_type, contents, file_obj):
        base_string = '''{ "touser": self.touser, "msgtype": msg_type, "agentid": self.agent_id, msg_type: {'%s': '%s'}, "safe": 0}'''
        if msg_type == 'text':
            values = base_string % ('content', contents)
        else:
            media_id = self._get_media_id(msg_type, file_obj)
            values = base_string % ('media_id', media_id)
        data = eval(values)
        js = json.dumps(data)
        to_bytes = bytes(js, 'utf-8')
        return to_bytes

    def send_message(self, msg_type, contents='', file_obj=None):
        post_msg = self._gen_msg(msg_type, contents, file_obj)
        arg_url = '/message/send?access_token={}'.format(self.token)
        url = self.base_url + arg_url
        requests.post(url, data=post_msg)
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/186721.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 远线程注入

    远线程注入OpenProcess函数打开现有的本地进程对象。HANDLEWINAPIOpenProcess(_In_DWORDdwDesiredAccess,_In_BOOLb

    2021年12月13日
    36
  • java数组转对象_java之数组和对象的互转「建议收藏」

    java数组转对象_java之数组和对象的互转「建议收藏」java*对象转bytes和bytes转对象**@projectorder*@fileNameByteUtil.java*@Description*@authorlight-zhang*@date2019年5月16日*@version1.0.0*/publicclassByteUtil{/***对象转数组**@paramobj*@return*/public…

    2022年9月10日
    0
  • hdparm

    “hdparm”(即硬盘参数)是Linux的命令行程序之一,用于处理磁盘设备和硬盘。借助此命令,您可以获得有关硬盘,更改写入间隔,声学管理和DMA设置的统计信息。它还可以设置与驱动器…

    2022年4月4日
    47
  • 五种聚类方法_聚类分析是一种降维方法吗

    五种聚类方法_聚类分析是一种降维方法吗本文为雷锋字幕组编译的技术博客,原标题The5ClusteringAlgorithmsDataScientistsNeedtoKnow,作者为GeorgeSeif。聚类是一种关于数据点分组的机器学习技术。给出一组数据点,我们可以使用聚类算法将每个数据点分类到特定的组中。理论上,同一组中的数据点应具有相似的属性或特征,而不同组中的数据点应具有相当不同的属性或特征(即类内差异小,…

    2022年10月20日
    0
  • jni断点调试「建议收藏」

    jni断点调试「建议收藏」jni断点调试

    2022年5月16日
    40
  • JVM内存模型详解(1.7与1.8的区别)[通俗易懂]

    JVM内存模型详解(1.7与1.8的区别)[通俗易懂]文章目录1.JDK、JRE、JVM关系2.JAVA程序的运行(为什么java可以跨平台)3.JVM运行时数据区1.JDK、JRE、JVM关系从图中就可以很清晰的看清他们之间的关系:JDK>JRE>JVM2.JAVA程序的运行(为什么java可以跨平台)比如我们编写一个HelloWord.java,他是如何运行的呢因为有JVM,所以我们在不同平台只需要下载对应的JDK即可…

    2022年5月16日
    43

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号