前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >[891]利用企业微信实现监控通知

[891]利用企业微信实现监控通知

作者头像
周小董
发布2022-04-13 15:02:25
6200
发布2022-04-13 15:02:25
举报
文章被收录于专栏:python前行者

文章目录

微信link

创建应用

未验证主体信息的账号只能有200个成员,发送次数的限制为:帐号上限数*30人次/天

注册完成后可以进入到后台管理页面,点击应用管理

在开始调用公众号的API之前,我们要先创建一个应用,告警可以发送到指定的应用中,同时我们还可以对应用授权,以限制可以看到告警的人员范围

创建完成后,点击应用图标可以看到以下页面

其中AgentId和Secret两个字段在后面的代码中要用到

微信API

要实现简单的消息发送,我们只需要用到两个微信的API接口

  • 获取token:https://work.weixin.qq.com/api/doc#10013
  • 发送消息:https://work.weixin.qq.com/api/doc#10167

代码实现

代码语言:javascript
复制
# -*- coding:utf-8 -*-
import json
import requests


class WeChatPub():

    def __init__(self,corpid='wwb1b',secret='tnbqWD0'):
        self.req = requests.session()
        self.token = self.get_token(corpid, secret)
        print("token is " + self.token)

    def get_token(self, corpid, secret):
        url = "https://qyapi.weixin.qq.com/cgi-bin/gettoken?corpid={0}&corpsecret={1}".format(corpid, secret)
        response = self.req.get(url)
        if response.status_code == 200:
            access_token=json.loads(response.content)['access_token']
            return access_token
        else:
            print("request failed.")
            return None

    def send_msg(self, content):
        url = "https://qyapi.weixin.qq.com/cgi-bin/message/send?access_token=" + self.token
        header = {
            "Content-Type": "application/json"
        }
        form_data = {
            "touser": "@all",
            "toparty": " PartyID1 | PartyID2 ",
            "totag": " TagID1 | TagID2 ",
            "msgtype": "textcard",
            "agentid": 1000002,
            "textcard": {
                "title": "领奖通知",
                "description": content,
                "url": "URL",
                "btntxt": "更多"
            },
            "safe": 0
        }
        data=json.dumps(form_data).encode('utf-8')
        rep = self.req.post(url, data=data, headers=header)
        if rep.status_code == 200:
            return json.loads(rep.content)
        else:
            print("request failed.")
            return None


if __name__ == '__main__':
    wechat = WeChatPub()
    msg='''<div class=\"gray\">2020年7月26日</div> 
    <div class=\"normal\">恭喜你抽中iPhone 7一台,领奖码:xxxx</div>
    <div class=\"highlight\">请于2020年10月10日前联系行政同事领取</div>'''
    wechat.send_msg(msg)
corpid

每个企业都拥有唯一的corpid,获取此信息可在管理后台“我的企业”-“企业信息”下查看“企业ID”(需要有管理员权限)

access_token

access_token是公众号的全局唯一票据,公众号调用各接口时都需使用access_token。

开发者需要缓存access_token,用于后续接口的调用(注意:不能频繁调用gettoken接口,否则会受到频率拦截)。当access_token失效或过期时,需要重新获取。

  • access_token的有效期通过返回的expires_in来传达,正常情况下为7200秒(2小时),有效期内重复获取返回相同结果,过期后获取会返回新的access_token。
  • 由于企业微信每个应用的access_token是彼此独立的,所以进行缓存时需要区分应用来进行存储。
  • access_token至少保留512字节的存储空间。
  • 企业微信可能会出于运营需要,提前使access_token失效,开发者应实现access_token失效时重新获取的逻辑。

执行以后在目标群里会收到以下信息:

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2020/08/15 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 文章目录
  • 微信link
  • 创建应用
  • 微信API
  • 代码实现
    • corpid
      • access_token
      领券
      问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档