Python基于钉钉监控发送消息提醒的实现

目录
  • 一.使用前设置钉钉
  • 二.安全设置
  • 三.发送请求
  • 四.完整代码

一.使用前设置钉钉

1.既然是使用钉钉消息提醒,那么第需要有钉钉。

2.第二步自定义机器人是群机器人,所以需要有个群。

3.添加机器人,点击头像>机器人管理>自定义机器人

4.给机器人取个名字>选择添加到哪个群组>选择适合自己的安全设置>完成

二.安全设置

1.有三种安全设置方式:自定义关键词、加签、IP地址。

2.自定义关键词:简单来说就是你发送的内容必须包含这个关键词,才能发送成功。

3.加签:就是生成你特定的签名,在程序中,进行加密生成参数,请求时,携带此参数,才能发送成功。

4.IP地址:就是在设置的指定IP地址范围内进行请求,才能发送成功。

5.选择适合自己的安全设置方式,这里选择的是加签,即配置好后,代码在使用、复用、迁移等方面会稍加灵活一点,如果在公司,按实际需求选择就行。把这个签名记录下来,待会需要它来加密生成参数。

6.点击完成之后,就可以看到自己的Webhook,记下来,待会需要用到。

三.发送请求

1.首先,在__init__方法中,配置好机器人的信息。

def __init__(self):
    # 安全设置使用加签方式
    timestamp = str(round(time.time() * 1000))
    secret = 'SEC7******fe0a'  # 刚才记录下来的签名
    secret_enc = secret.encode('utf-8')
    string_to_sign = '{}\n{}'.format(timestamp, secret)
    string_to_sign_enc = string_to_sign.encode('utf-8')
    hmac_code = hmac.new(secret_enc, string_to_sign_enc, digestmod=hashlib.sha256).digest()
    sign = urllib.parse.quote_plus(base64.b64encode(hmac_code))
	# 以上就是加签的安全配置,其它安全设置,无需配置以上信息

    # webhook地址
    webhook = 'https://oapi.dingtalk.com/robot/send?******'  # 刚才记录的webhook
    self.webhook = "{}&timestamp={}&sign={}".format(webhook, timestamp, sign)  # 如果你的不是加签的安全方式,即可省去 &timestamp={}&sign={} 部分参数
    # 配置请求headers
    self.headers = {
        "Content-Type": "application/json",
        "Charset": "UTF-8"  # 发起POST请求时,必须将字符集编码设置成UTF-8。
    }

2.其次,发送请求

def send_req(self, message):
    """
    发送请求
    :param message: 你的消息体
    :return:
    """
    # 将请求数据进行json数据封装
    form_data = json.dumps(message)
    # 发起请求
    res_info = requests.post(url=self.webhook, headers=self.headers, data=form_data)
    # 打印返回的结果
    print('邮件发送结果:', res_info.json())
    print('通知成功!' if (res_info.json())['errmsg'] == 'ok' else '通知失败!')

3.再次,构造消息体,钉钉给出6种消息类型体

3.1.第一种、text型文本数据

def send_text_msg(self, content, at_mobiles=None, is_at_all=False):
    """
    发送text型文本数据
    :param content: 消息内容
    :param at_mobiles: 传入列表类型数据,@出现在列表中的电话联系人,如果群里没有该联系人,则不会@(可选参数)
    :param is_at_all: 是否@所有人,默认不艾特(可选参数)
    :return:
    """
    message = {
        "msgtype": "text",  # 消息类型
        "text": {
            "content": content
        },
        "at": {
            "atMobiles": at_mobiles,
            "isAtAll": is_at_all
        }
    }
    self.send_req(message)  # 发送消息

a.调用

DingTalkWarn().send_text_msg('测试消息发送!')

b.效果图

3.2.第二种、link型文本数据

def send_link_msg(self, text, title, message_url, pic_url=None):
    """
    发送link型文本数据
    :param text: 消息内容
    :param title: 消息标题
    :param message_url: 点击消息跳转的URL
    :param pic_url: 图片URL(可选参数)
    :return:
    """
    message = {
        "msgtype": "link",
        "link": {
            "text": text,  # 消息内容,如果太长只会部分展示
            "title": title,  # 消息标题
            "picUrl": pic_url,  # 图片URL
            "messageUrl": message_url  # 点击消息跳转的URL
        }
    }
    self.send_req(message)  # 发送消息

a.调用

DingTalkWarn().send_link_msg(
        text='爱分享,爱折腾,爱生活,乐于分享自己在学习过程中的一些心得、体会。',
        title='a'ゞ开心果的博客',
        message_url='https://blog.csdn.net/qq_45352972',
        pic_url='https://cdn.jsdelivr.net/gh/King-ing/CDN/assets/background.png'
    )

b.效果图

3.3.第三种、markdown型文本数据

def send_markdown_msg(self, text, title, at_mobiles=None, is_at_all=False):
    """
    发送markdown型文本数据
    :param text: markdown格式内容
    :param title: 标题
    :param at_mobiles: 传入列表类型数据,@出现在列表中的电话联系人,如果群里没有该联系人,则不会@(可选参数)
    :param is_at_all: 是否@所有人,默认不艾特(可选参数)
    :return:
    """
    message = {
        "msgtype": "markdown",
        "markdown": {
            "title": title,
            "text": text
        },
        "at": {
            "atMobiles": at_mobiles,
            "isAtAll": is_at_all
        }
    }
    self.send_req(message)  # 发送消息

a.调用

DingTalkWarn().send_markdown_msg(
        text="## 这是一个二级标题\n ![news](https://cdn.jsdelivr.net/gh/King-ing/CDN/assets/background.png)\n###### {}发布".format(time.strftime("%Y-%m-%d %H:%M:%S")),
        title='markdown格式数据',
    )

b.效果图

3.4.第四种、整体跳转ActionCard类型的数据

def send_all_action_card_msg(self, text, title, single_url, single_title='阅读全文'):
    """
    发送整体跳转ActionCard类型的数据
    :param text: markdown格式内容
    :param title: 标题
    :param single_url: 详情url地址
    :param single_title: 点击进入详情按钮
    :return:
    """
    message = {
        "actionCard": {
            "title": title,
            "text": text,
            "singleTitle": single_title,
            "singleURL": single_url
        },
        "msgtype": "actionCard"
    }
    self.send_req(message)  # 发送消息

a.调用

DingTalkWarn().send_all_action_card_msg(
        text='## 抓包工具-mitmproxy前奏\n ![](https://img-blog.csdnimg.cn/20201211103655824.png?x-oss-process=image/watermark,type_ZmFuZ3poZW5naGVpdGk,shadow_10,text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L3FxXzQ1MzUyOTcy,size_16,color_FFFFFF,t_70)\n介绍:mitmproxy类似于Fiddler、Charles的功能,可以支持HTTP跟HTTPS请求,只不过它是通过控制台的形式进行操作。mitmproxy有两个关联的组件,mitmdump跟mitmweb。mitmdump是mitmproxy的命令行接口;mitmweb是一个web程序,可以通...',
        title='抓包工具-mitmproxy前奏',
        single_url='https://blog.csdn.net/qq_45352972/article/details/111028741?spm=1001.2014.3001.5501'
    )

b.效果图

3.5.第五种、独立跳转ActionCard类型的数据

def send_alone_action_card_msg(self, text, title, btn_orientation=1, btns=None):
    """
    发送独立跳转ActionCard类型的数据
    :param text: markdown格式文本数据
    :param title: 标题
    :param btn_orientation: 0-按钮竖直排列;1-按钮横向排列
    :param btns: 列表数据,里面存字符串,用来放按钮信息跟链接,如下
            [
                {
                    "title": "内容不错",
                    "actionURL": "https://www.dingtalk.com/"
                },
                {
                    "title": "不感兴趣",
                    "actionURL": "https://www.dingtalk.com/"
                }
            ]
    :return:
    """
    message = {
        "msgtype": "actionCard",
        "actionCard": {
            "title": title,
            "text": text,
            "hideAvatar": "0",
            "btnOrientation": btn_orientation,
            "btns": btns
        }
    }

    self.send_req(message)  # 发送消息

a.调用

DingTalkWarn().send_alone_action_card_msg(
        text='### 查看好友博客\n![](https://profile.csdnimg.cn/C/B/7/1_qq_45352972)',
        title='查看好友博客',
        btns=[
            {
                "title": "不感兴趣",
                "actionURL": "https://www.dingtalk.com/"
            },
            {
                "title": "我看看",
                "actionURL": "https://blog.csdn.net/qq_45352972/"
            }
        ]

    )

b.效果图

3.6.第六种、FeedCard类型数据

def send_feed_card_msg(self, links):
    """
    发送FeedCard类型数据
    :param links: 列表类型,格式如下
            [
                {
                    "title": "时代的火车向前开1",
                    "messageURL": "https://www.dingtalk.com/",
                    "picURL": "https://img.alicdn.com/tfs/TB1NwmBEL9TBuNjy1zbXXXpepXa-2400-1218.png"
                },
                {
                    "title": "时代的火车向前开2",
                    "messageURL": "https://www.dingtalk.com/",
                    "picURL": "https://img.alicdn.com/tfs/TB1NwmBEL9TBuNjy1zbXXXpepXa-2400-1218.png"
                }
            ]
    :return:
    """
    message = {
        "msgtype": "feedCard",
        "feedCard": {
            "links": links
        }
    }
    self.send_req(message)  # 发送消息

a.调用

DingTalkWarn().send_feed_card_msg(
        links=[
            {
                "title": "爬虫之解决需要登录的网站",
                "messageURL": "https://blog.csdn.net/qq_45352972/article/details/113831698?spm=1001.2014.3001.5501",
                "picURL": "https://img-blog.csdnimg.cn/20210217102838577.png?x-oss-process=image/watermark,type_ZmFuZ3poZW5naGVpdGk,shadow_10,text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L3FxXzQ1MzUyOTcy,size_16,color_FFFFFF,t_70#pic_center"
            },
            {
                "title": "控制台简单实现打印显示进度条",
                "messageURL": "https://blog.csdn.net/qq_45352972/article/details/112191329?spm=1001.2014.3001.5501",
                "picURL": "https://img-blog.csdnimg.cn/20210104184651355.png?x-oss-process=image/watermark,type_ZmFuZ3poZW5naGVpdGk,shadow_10,text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L3FxXzQ1MzUyOTcy,size_16,color_FFFFFF,t_70"
            },
            {
                "title": "Email邮件提醒",
                "messageURL": "https://blog.csdn.net/qq_45352972/article/details/109280576?spm=1001.2014.3001.5501",
                "picURL": "https://img-blog.csdnimg.cn/2020102522530334.png?x-oss-process=image/watermark,type_ZmFuZ3poZW5naGVpdGk,shadow_10,text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L3FxXzQ1MzUyOTcy,size_16,color_FFFFFF,t_70#pic_center"
            }
        ]
    )

b.效果图

四.完整代码

import base64
import hashlib
import hmac
import time
import urllib.parse
import requests
import json

class DingTalkWarn:
    """钉钉消息通知"""

    def __init__(self):
        # 安全设置使用加签方式
        timestamp = str(round(time.time() * 1000))
        # 刚才记录下来的签名
        secret = 'SEC24e640447734a80b9d430d678765a103652b33f334a69974cfda88415e601d22'
        secret_enc = secret.encode('utf-8')
        string_to_sign = '{}\n{}'.format(timestamp, secret)
        string_to_sign_enc = string_to_sign.encode('utf-8')
        hmac_code = hmac.new(secret_enc, string_to_sign_enc, digestmod=hashlib.sha256).digest()
        sign = urllib.parse.quote_plus(base64.b64encode(hmac_code))
        # 以上就是加签的安全配置,其它安全设置,无需配置以上信息

        # webhook地址(刚才记录的webhook)
        webhook = 'https://oapi.dingtalk.com/robot/send?access_token=5f56131ba70c78f42a10c7e9531c8da55def990313a4a74cfc87bf82c4bb8b7b'
        # 如果你的不是加签的安全方式,即可省去 &timestamp={}&sign={} 部分参数
        self.webhook = "{}&timestamp={}&sign={}".format(webhook, timestamp, sign)
        # 配置请求headers
        self.headers = {
            "Content-Type": "application/json",
            "Charset": "UTF-8"          # 发起POST请求时,必须将字符集编码设置成UTF-8。
        }

    def send_text_msg(self, content, at_mobiles=None, is_at_all=False):
        """
        发送text型文本数据
        :param content: 消息内容
        :param at_mobiles: 传入列表类型数据,@出现在列表中的电话联系人,如果群里没有该联系人,则不会@(可选参数)
        :param is_at_all: 是否@所有人,默认不艾特(可选参数)
        :return:
        """
        message = {
            "msgtype": "text",  # 消息类型
            "text": {
                "content": content
            },
            "at": {
                "atMobiles": at_mobiles,
                "isAtAll": is_at_all
            }
        }
        self.send_req(message)  # 发送消息

    def send_link_msg(self, text, title, message_url, pic_url=None):
        """
        发送link型文本数据
        :param text: 消息内容
        :param title: 消息标题
        :param message_url: 点击消息跳转的URL
        :param pic_url: 图片URL(可选参数)
        :return:
        """
        message = {
            "msgtype": "link",
            "link": {
                "text": text,  # 消息内容,如果太长只会部分展示
                "title": title,  # 消息标题
                "picUrl": pic_url,  # 图片URL
                "messageUrl": message_url  # 点击消息跳转的URL
            }
        }
        self.send_req(message)  # 发送消息

    def send_markdown_msg(self, text, title, at_mobiles=None, is_at_all=False):
        """
        发送markdown型文本数据
        :param text: markdown格式内容
        :param title: 标题
        :param at_mobiles: 传入列表类型数据,@出现在列表中的电话联系人,如果群里没有该联系人,则不会@(可选参数)
        :param is_at_all: 是否@所有人,默认不艾特(可选参数)
        :return:
        """
        message = {
            "msgtype": "markdown",
            "markdown": {
                "title": title,
                "text": text
            },
            "at": {
                "atMobiles": at_mobiles,
                "isAtAll": is_at_all
            }
        }
        self.send_req(message)  # 发送消息

    def send_all_action_card_msg(self, text, title, single_url, single_title=u'阅读全文'):
        """
        发送整体跳转ActionCard类型的数据
        :param text: markdown格式内容
        :param title: 标题
        :param single_url: 详情url地址
        :param single_title: 点击进入详情按钮
        :return:
        """
        message = {
            "actionCard": {
                "title": title,
                "text": text,
                "singleTitle": single_title,
                "singleURL": single_url
            },
            "msgtype": "actionCard"
        }
        self.send_req(message)  # 发送消息

    def send_alone_action_card_msg(self, text, title, btn_orientation=1, btns=None):
        """
        发送独立跳转ActionCard类型的数据
        :param text: markdown格式文本数据
        :param title: 标题
        :param btn_orientation: 0-按钮竖直排列;1-按钮横向排列
        :param btns: 列表数据,里面存字符串,用来放按钮信息跟链接,如下
                [
                    {
                        "title": "内容不错",
                        "actionURL": "https://www.dingtalk.com/"
                    },
                    {
                        "title": "不感兴趣",
                        "actionURL": "https://www.dingtalk.com/"
                    }
                ]
        :return:
        """
        message = {
            "msgtype": "actionCard",
            "actionCard": {
                "title": title,
                "text": text,
                "hideAvatar": "0",
                "btnOrientation": btn_orientation,
                "btns": btns
            }
        }

        self.send_req(message)  # 发送消息

    def send_feed_card_msg(self, links):
        """
        发送FeedCard类型数据
        :param links: 列表类型,格式如下
                [
                    {
                        "title": "时代的火车向前开1",
                        "messageURL": "https://www.dingtalk.com/",
                        "picURL": "https://img.alicdn.com/tfs/TB1NwmBEL9TBuNjy1zbXXXpepXa-2400-1218.png"
                    },
                    {
                        "title": "时代的火车向前开2",
                        "messageURL": "https://www.dingtalk.com/",
                        "picURL": "https://img.alicdn.com/tfs/TB1NwmBEL9TBuNjy1zbXXXpepXa-2400-1218.png"
                    }
                ]
        :return:
        """
        message = {
            "msgtype": "feedCard",
            "feedCard": {
                "links": links
            }
        }
        self.send_req(message)  # 发送消息

    def send_req(self, message):
        """
        发送请求
        :param message: 你的消息体
        :return:
        """
        # 将请求数据进行json数据封装
        form_data = json.dumps(message)
        # 发起请求
        res_info = requests.post(url=self.webhook, headers=self.headers, data=form_data)
        # 打印返回的结果
        print(u'邮件发送结果:', res_info.json())
        print(u'通知成功!' if (res_info.json())['errmsg'] == 'ok' else u'通知失败!')

if __name__ == '__main__':
    """测试发送消息"""
    DingTalkWarn().send_text_msg(u'测试消息发送!')

    """
    DingTalkWarn().send_link_msg(
            text='爱分享,爱折腾,爱生活,乐于分享自己在学习过程中的一些心得、体会。',
            title='a'ゞ开心果的博客',
            message_url='https://blog.csdn.net/qq_45352972',
            pic_url='https://cdn.jsdelivr.net/gh/King-ing/CDN/assets/background.png'
    )

    DingTalkWarn().send_markdown_msg(
            text="## 这是一个二级标题\n ![news](https://cdn.jsdelivr.net/gh/King-ing/CDN/assets/background.png)\n###### {}发布".format(time.strftime("%Y-%m-%d %H:%M:%S")),
            title='markdown格式数据',
    )

    DingTalkWarn().send_all_action_card_msg(
            text='## 抓包工具-mitmproxy前奏\n ![](https://img-blog.csdnimg.cn/20201211103655824.png?x-oss-process=image/watermark,type_ZmFuZ3poZW5naGVpdGk,shadow_10,text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L3FxXzQ1MzUyOTcy,size_16,color_FFFFFF,t_70)\n介绍:mitmproxy类似于Fiddler、Charles的功能,可以支持HTTP跟HTTPS请求,只不过它是通过控制台的形式进行操作。mitmproxy有两个关联的组件,mitmdump跟mitmweb。mitmdump是mitmproxy的命令行接口;mitmweb是一个web程序,可以通...',
            title='抓包工具-mitmproxy前奏',
            single_url='https://blog.csdn.net/qq_45352972/article/details/111028741?spm=1001.2014.3001.5501'
    )

    DingTalkWarn().send_alone_action_card_msg(
            text='### 查看好友博客\n![](https://profile.csdnimg.cn/C/B/7/1_qq_45352972)',
            title='查看好友博客',
            btns=[
                {"title": "不感兴趣",
                 "actionURL": "https://www.dingtalk.com/"
                 },
                {
                    "title": "我看看",
                    "actionURL": "https://blog.csdn.net/qq_45352972/"
                }
            ]
    )

    DingTalkWarn().send_feed_card_msg(
            links=[
                {
                    "title": "爬虫之解决需要登录的网站",
                    "messageURL": "https://blog.csdn.net/qq_45352972/article/details/113831698?spm=1001.2014.3001.5501",
                    "picURL": "https://img-blog.csdnimg.cn/20210217102838577.png?x-oss-process=image/watermark,type_ZmFuZ3poZW5naGVpdGk,shadow_10,text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L3FxXzQ1MzUyOTcy,size_16,color_FFFFFF,t_70#pic_center"
                },
                {
                    "title": "控制台简单实现打印显示进度条",
                    "messageURL": "https://blog.csdn.net/qq_45352972/article/details/112191329?spm=1001.2014.3001.5501",
                    "picURL": "https://img-blog.csdnimg.cn/20210104184651355.png?x-oss-process=image/watermark,type_ZmFuZ3poZW5naGVpdGk,shadow_10,text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L3FxXzQ1MzUyOTcy,size_16,color_FFFFFF,t_70"
                },
                {
                    "title": "Email邮件提醒",
                    "messageURL": "https://blog.csdn.net/qq_45352972/article/details/109280576?spm=1001.2014.3001.5501",
                    "picURL": "https://img-blog.csdnimg.cn/2020102522530334.png?x-oss-process=image/watermark,type_ZmFuZ3poZW5naGVpdGk,shadow_10,text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L3FxXzQ1MzUyOTcy,size_16,color_FFFFFF,t_70#pic_center"
                }
            ]
    )
    """

到此这篇关于Python基于钉钉监控发送消息提醒的实现的文章就介绍到这了,更多相关Python 钉钉监控发送消息提醒内容请搜索我们以前的文章或继续浏览下面的相关文章希望大家以后多多支持我们!

时间: 2022-06-23

Python实现钉钉发送报警消息的方法

钉钉开放平台传送门:https://open.dingtalk.com 我司使用钉钉作为内部通讯工具,基本上大家在电脑和手机上都开着,消息可以第一时间查看,报警消息的即时性要求比较高,所以适合用钉钉通知. 下面介绍如何用Python实现钉钉发送报警消息. 获取access token 要使用钉钉发送消息,首先需要获取access token,代码如下: def get_access_token(): url = 'https://oapi.dingtalk.com/gettoken?corpid

python自动化UI工具发送QQ消息的实例

概述 个人遇到过小的需求,windows自动水群发送垃圾消息,使用一些特别简单易上手的小工具,快速实现功能需求(而不是使用一些重量级的还需要额外花时间去熟悉功能语法的大工具,如UI自动化工具sikulix).在一番摸索下,得出一番结论: 对于多平台的UI自动复杂操作,还是去学sikulix吧,这不是啃一点win32 api获取窗口句柄就能轻松解决的,毕竟sikulix是MIT大佬折腾出来的.而且,原理也更复杂(通过使用opencv对窗体控件进行识别,进而实现控制操作). 对于简单的操作(控制剪切

python 使用 requests 模块发送http请求 的方法

Requests具有完备的中英文文档, 能完全满足当前网络的需求, 它使用了urllib3, 拥有其所有的特性! 最近在学python自动化,怎样用python发起一个http请求呢? 通过了解 request 模块可以帮助我们发起http请求 步骤: 1.首先import 下 request 模块 2.然后看请求的方式,选择对应的请求方法 3.接受返回的报文信息 例子:get 方法 import requests url ="https://www.baidu.com" res =

微信小程序发送订阅消息的方法(php 为例)

1.订阅消息 其实如果用过模板消息的话,改用订阅消息挺简单的,看一下官方文档稍加摸索就能使用. 但是对于那些第一次用的萌新来说,可能会遇到各种各样的坑,所以我会具体的说一下实现的过程,有经验的可以直接翻到文章底部查看 Demo. 虽然如此,但是更详细的参数描述还是需要去看官方文档,传送门: https://developers.weixin.qq.com/miniprogram/dev/framework/open-ability/subscribe-message.html 2.准备工作 首先

zabbix利用python脚本发送报警邮件的方法

前言 zabbix是个非常强大的监控工具,可以监控linux和windows的服务器数据,也可以通过自定义key来扩展默认的监控项,但是自带的邮件报警提供的信息却不太友善.本文想通过自定脚本的方式,实现在报警邮件的同时发送对应的图像和url连接. 步骤如下: 1.编辑zabbix_server.conf文件,修改AlertScriptsPath参数,该参数用于指定外部脚本的绝对路径. vim /etc/zabbix/zabbix_server.conf AlertScriptsPath=/usr

python itchat给指定联系人发消息的方法

itchat模块 官方参考文档:https://itchat.readthedocs.io/zh/latest/ 安装 pip install itchat / pip3 install itchat 原理 Python模仿网页版微信登陆,并且现有一套操作网页版微信的API,可以将你使用微信中产生的数据爬下来,并做出相应的处理. 操作 1.导入这套微信API的包itchat import itchat 2.模仿网页版微信登陆 itchat.auto_login() 3.使用相关函数找到相关微信联

钉钉群自定义机器人消息Python封装的实例

一.钉钉群自定义机器人介绍 钉钉群机器人是钉钉群的一个高级扩展功能,然而使用起来却非常简单,只有注册一个钉钉账号即可,就可以将第三方服务的信息聚合到钉钉群中,实现信息的自动化同步,例如:通过聚合Github.Gitlab等源码管理服务,实现源码更新同步:通过聚合Trello.JIRA等项目协调服务,实现项目信息同步:同事,支持Webhook协议的自定义接入,支持更多可能性,例如:将运维报警提醒.自动化测试的结果报告提醒.工作.生活日程安排(上班打卡.下班吃饭.健身.读书.生日.纪念日-)等等的提

浅谈Python 钉钉报警必备知识系统讲解

本章所讲内容: 1.钉钉报警设置 2.钉钉报警脚本运行. 1.钉钉报警设置 钉钉,关于webhook的报警需求,钉钉报警也是我们在公司中常见的报警系统,在这里主要是结合zabbix二次开发使用,来达到完美报警的使用. 1.1.钉钉报警第一步,创建群机器人 接口地址: https://oapi.dingtalk.com/robot/send?access_token=a25324cafc5b0f2bb239b5e56c71e7f378f570a3d281160dbec9e4f8c4a7e493 文

Python钉钉报警及Zabbix集成钉钉报警的示例代码

钉钉报警设置 创建群机器人 接口地址 发送短消息 发送普通消息 import requests import json url = 'https://oapi.dingtalk.com/robot/send?access_token=71638980426c030' headers = { "Content-Type": "application/json", "Chartset": "utf-8" } # 要发送的文本是js

Python实现钉钉订阅消息功能

钉钉设置机器人 首先在钉钉设置钉钉机器人 群设置-> 智能群助手->添加机器人->自定义 添加完成,得到一个Webhook API地址 Python脚本实现推送钉钉消息 钉钉官方给出了机器人接口的文档:https://ding-doc.dingtalk.com/doc#/serverapi2/qf2nxq 但是该文档只实现了JAVA和PHP的示例.以下是python脚本的示例. # -*- coding: utf-8 -*- """Created on Mo