一、注册微信企业号
因为订阅号的发送数量有限,很多时候超额发送之后会无法发送,现在我们申请企业号,因为企业号可以无限制的发送报警信息。
打开注册地址https://qy.weixin.qq.com/。
1、填写账号密码信息
2、邮箱激活
3、选择企业号
4、填写相关信息,注册成功
二、配置企业号
1、通讯录添加企业成员
我们要提前把成员信息添加进组织部门,必填项+手机号或者微信号,这样别人扫描二维码的时候才能成功关注企业号。
注意:这里有两个我们要用到信息,一个组织部门的ID,一个部门成员的账号(账号是自己手动指定的,不同于微信号,最好是字母加数字)
查看部门id,修改部门即可看到。
在部门添加新成员。
人员为扫描之前是?,扫描添加之后就正常了。
2、应用中心创建应用
我们要在这里创建应用,因为要通过应用发送消息给部门成员,可以创建多个,不同的业务通过不同的应用发送出去,我这里创建的是运维部,这里要记住一个值,应用ID,后面的发送脚本会用到。
3、给部门设置管理组
设置--->功能设置---->权限管理---->新建管理组,按照相应的信息设定好应用权限以及通讯录权限,里面的CorpID和Secret是我们后面脚本需要的。
三、调用微信接口
调用微信接口需要一个调用接口的凭证:access_token,通过CropID 、Secret才能获取到access_token,但是获取到的token有效期为两分钟。
微信企业号接口调试工具传送门:http://qydev.weixin.qq.com/debug。
微信接口消息类型及格式。
http://qydev.weixin.qq.com/wiki/index.php?title=%E6%B6%88%E6%81%AF%E7%B1%BB%E5%9E%8B%E5%8F%8A%E6%95%B0%E6%8D%AE%E6%A0%BC%E5%BC%8F
1、编辑微信Python脚本
1
|
# cat /usr/local/zabbix/alertscripts/yunwei.py
|
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
|
#!/usr/bin/python
#coding:utf-8
import
urllib2
import
json
import
sys
def
getMsg(zabbix_msg):
reload
(sys)
sys.setdefaultencoding(
'utf8'
)
msg
=
' '
.join(zabbix_msg)
msg
=
msg.split(
'#'
)
mes
=
"\n"
.join(msg)
return
"\n"
.join(msg)
if
__name__
=
=
'__main__'
:
#微信公众号上应用的CropID和Secret
CropID
=
'wx8d46d36104988993'
Secret
=
'QCjzy2lH2ZB7MUG6uowChyChPssfsf6EB0X0QjofRRt0JePGezTVR4saIw3Ezznh'
#获取access_token
GURL
=
"https://qyapi.weixin.qq.com/cgi-bin/gettoken?corpid=%s&corpsecret=%s"
%
(CropID,Secret)
result
=
urllib2.urlopen(urllib2.Request(GURL)).read()
dict_result
=
json.loads(result)
dict_result.keys()
Gtoken
=
dict_result[
'access_token'
]
#生成通过post请求发送消息的url
PURL
=
"https://qyapi.weixin.qq.com/cgi-bin/message/send?access_token=%s"
%
(Gtoken)
AppID
=
4
#企业号中的应用id
# UserID=2 #部门成员id,zabbix中定义的微信接收者
PartyID
=
2
#部门id,定义了范围,组内成员都可接收到消息
#生成post请求信息
post_data
=
{}
news
=
{}
articles
=
{}
articles[
'description'
]
=
getMsg(sys.argv[
3
:])
articles[
'title'
]
=
getMsg(sys.argv[
2
:
3
])
news[
'articles'
]
=
[articles]
#post_data['touser'] = UserID
post_data[
'toparty'
]
=
PartyID
post_data[
'msgtype'
]
=
'news'
post_data[
'agentid'
]
=
AppID
post_data[
'news'
]
=
news
#post_data['safe'] = '0'
#由于字典格式不能被识别,需要转换成json然后在作post请求
#注:如果要发送的消息内容有中文的话,第三个参数一点要设为False
json_post_data
=
json.dumps(post_data,
False
,
False
)
#通过urllib2.urlopen()方法发送post请求
request_post
=
urllib2.urlopen(PURL, json_post_data)
#read()方法查看请求的返回结果
print
request_post.read()
|
2、配置脚本权限
1
2
|
chown
zabbix.zabbix
/usr/local/zabbix/alertscripts/yunwei
.py
chmod
+x
/usr/local/zabbix/alertscripts/yunwei
.py
|
3、测试脚本
由脚本可以看出,我们不但可以使用zabbix报警,也可以使用任何shell报警。
1
2
|
[root@monitor alertscripts]
# python /usr/local/zabbix/alertscripts/yunwei.py test
{
"errcode"
:0,
"errmsg"
:
"ok"
}
|
可以看到可以正常的调用接口,我们接着配置zabbix。
四、配置Zabbix
1、创建媒介
2、给用户增加媒介
3、创建触发器
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
|
======================================================
服务器:{HOST.NAME}发生: {TRIGGER.NAME}故障!
{
告警主机:{HOST.NAME}
告警地址:{HOST.IP}
告警时间:{EVENT.DATE} {EVENT.TIME}
告警等级:{TRIGGER.SEVERITY}
告警信息:{TRIGGER.NAME}
监控项目:{ITEM.NAME}
当前状态:{TRIGGER.STATUS}
持续时间:{EVENT.AGE}
事件ID:{EVENT.ID}
监控取值:{ITEM.LASTVALUE}
}
=====================================================
服务器:{HOST.NAME}: {TRIGGER.NAME}已恢复!
{
告警主机:{HOST.NAME}
告警地址:{HOST.IP}
告警时间:{EVENT.DATE} {EVENT.TIME}
恢复时间:{EVENT.RECOVERY.DATE} {EVENT.RECOVERY.TIME}
告警等级:{TRIGGER.SEVERITY}
告警信息:{TRIGGER.NAME}
监控项目:{ITEM.NAME}
当前状态:{TRIGGER.STATUS}
持续时间:{EVENT.AGE}
事件ID:{EVENT.ID}
监控取值:{ITEM.LASTVALUE}
}
====================================================
|
Send only to选择我们设定的媒介。
3、测试
附录:Shell脚本
1、编辑微信Shell脚本
上面是Python的脚本,下面我贴一下Shell的脚本,其他的配置信息都是一样的,使用其中一个就可以了。
1
|
# cat /usr/local/zabbix/alertscripts/yunwei.sh
|
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
|
#!/bin/bash
#########################################################################
# File Name: yunwei_bash.sh
# Author: wzlinux
# Email: [email protected]
# Created Time: 2017.4.17
#########################################################################
# Functions: send messages to wechat app
# set variables
CropID=
'wx8d46d36104988993'
Secret=
'QCjzy2lH2ZB7MUG6uowChyChPsOQwsdf0X0QjofRRt0JePGezTVR4saIw3Ezznh'
GURL=
"https://qyapi.weixin.qq.com/cgi-bin/gettoken?corpid=$CropID&corpsecret=$Secret"
#get acccess_token
Gtoken=$(
/usr/bin/curl
-s -G $GURL |
awk
-F\"
'{print $4}'
)
PURL=
"https://qyapi.weixin.qq.com/cgi-bin/message/send?access_token=$Gtoken"
#
function
body() {
local
int AppID=4
#企业号中的应用id
#local UserID="eric" #部门成员id,zabbix中定义的微信接收者
local
PartyID=2
#部门id,定义了范围,组内成员都可接收到消息
local
Msg=$(
echo
"$@"
|
cut
-d
" "
-f3-)
#过滤出zabbix传递的第三个参数
printf
'{\n'
printf
'\t"touser": "'
"$UserID
"\""
,\n"
printf
'\t"toparty": "'
"$PartyID
"\""
,\n"
printf
'\t"msgtype": "text",\n'
printf
'\t"agentid": "'
" $AppID
"\""
,\n"
printf
'\t"text": {\n'
printf
'\t\t"content": "'
"$Msg
"\""
\n"
printf
'\t},\n'
printf
'\t"safe":"0"\n'
printf
'}\n'
}
/usr/bin/curl
--data-ascii
"$(body $1 $2 $3)"
$PURL
|
1
2
|
chown
zabbix.zabbix
/usr/local/zabbix/alertscripts/yunwei
.sh
chmod
+x
/usr/local/zabbix/alertscripts/yunwei
.sh
|
5、测试
# bash yunwei.sh test Hello.World!
{"errcode":0,"errmsg":"ok"}
这里我不再进行截图了,我这边测试是通过的
本文转自 wzlinux 51CTO博客,原文链接:http://blog.51cto.com/wzlinux/1916772,如需转载请自行联系原作者
文章浏览阅读645次。这个肯定是末尾的IDAT了,因为IDAT必须要满了才会开始一下个IDAT,这个明显就是末尾的IDAT了。,对应下面的create_head()代码。,对应下面的create_tail()代码。不要考虑爆破,我已经试了一下,太多情况了。题目来源:UNCTF。_攻防世界困难模式攻略图文
文章浏览阅读2.9k次,点赞3次,收藏10次。偶尔会用到,记录、分享。1. 数据库导出1.1 切换到dmdba用户su - dmdba1.2 进入达梦数据库安装路径的bin目录,执行导库操作 导出语句:./dexp cwy_init/[email protected]:5236 file=cwy_init.dmp log=cwy_init_exp.log 注释: cwy_init/init_123..._达梦数据库导入导出
文章浏览阅读1.9k次。1. 在官网上下载KindEditor文件,可以删掉不需要要到的jsp,asp,asp.net和php文件夹。接着把文件夹放到项目文件目录下。2. 修改html文件,在页面引入js文件:<script type="text/javascript" src="./kindeditor/kindeditor-all.js"></script><script type="text/javascript" src="./kindeditor/lang/zh-CN.js"_kindeditor.js
文章浏览阅读2.3k次,点赞6次,收藏14次。SPI的详情简介不必赘述。假设我们通过SPI发送0xAA,我们的数据线就会变为10101010,通过修改不同的内容,即可修改SPI中0和1的持续时间。比如0xF0即为前半周期为高电平,后半周期为低电平的状态。在SPI的通信模式中,CPHA配置会影响该实验,下图展示了不同采样位置的SPI时序图[1]。CPOL = 0,CPHA = 1:CLK空闲状态 = 低电平,数据在下降沿采样,并在上升沿移出CPOL = 0,CPHA = 0:CLK空闲状态 = 低电平,数据在上升沿采样,并在下降沿移出。_stm32g431cbu6
文章浏览阅读1.2k次,点赞2次,收藏8次。数据链路层习题自测问题1.数据链路(即逻辑链路)与链路(即物理链路)有何区别?“电路接通了”与”数据链路接通了”的区别何在?2.数据链路层中的链路控制包括哪些功能?试讨论数据链路层做成可靠的链路层有哪些优点和缺点。3.网络适配器的作用是什么?网络适配器工作在哪一层?4.数据链路层的三个基本问题(帧定界、透明传输和差错检测)为什么都必须加以解决?5.如果在数据链路层不进行帧定界,会发生什么问题?6.PPP协议的主要特点是什么?为什么PPP不使用帧的编号?PPP适用于什么情况?为什么PPP协议不_接收方收到链路层数据后,使用crc检验后,余数为0,说明链路层的传输时可靠传输
文章浏览阅读587次。软件测试工程师移民加拿大 无证移民,未受过软件工程师的教育(第1部分) (Undocumented Immigrant With No Education to Software Engineer(Part 1))Before I start, I want you to please bear with me on the way I write, I have very little gen...
文章浏览阅读304次。Thinkpad X250笔记本电脑,装的是FreeBSD,进入BIOS修改虚拟化配置(其后可能是误设置了安全开机),保存退出后系统无法启动,显示:secure boot failed ,把自己惊出一身冷汗,因为这台笔记本刚好还没开始做备份.....根据错误提示,到bios里面去找相关配置,在Security里面找到了Secure Boot选项,发现果然被设置为Enabled,将其修改为Disabled ,再开机,终于正常启动了。_安装完系统提示secureboot failure
文章浏览阅读10w+次,点赞93次,收藏352次。1、用strtok函数进行字符串分割原型: char *strtok(char *str, const char *delim);功能:分解字符串为一组字符串。参数说明:str为要分解的字符串,delim为分隔符字符串。返回值:从str开头开始的一个个被分割的串。当没有被分割的串时则返回NULL。其它:strtok函数线程不安全,可以使用strtok_r替代。示例://借助strtok实现split#include <string.h>#include <stdio.h&_c++ 字符串分割
文章浏览阅读2.3k次。1 .高斯日记 大数学家高斯有个好习惯:无论如何都要记日记。他的日记有个与众不同的地方,他从不注明年月日,而是用一个整数代替,比如:4210后来人们知道,那个整数就是日期,它表示那一天是高斯出生后的第几天。这或许也是个好习惯,它时时刻刻提醒着主人:日子又过去一天,还有多少时光可以用于浪费呢?高斯出生于:1777年4月30日。在高斯发现的一个重要定理的日记_2013年第四届c a组蓝桥杯省赛真题解答
文章浏览阅读851次,点赞17次,收藏22次。摘要:本文利用供需算法对核极限学习机(KELM)进行优化,并用于分类。
文章浏览阅读1.1k次。一、系统弱密码登录1、在kali上执行命令行telnet 192.168.26.1292、Login和password都输入msfadmin3、登录成功,进入系统4、测试如下:二、MySQL弱密码登录:1、在kali上执行mysql –h 192.168.26.129 –u root2、登录成功,进入MySQL系统3、测试效果:三、PostgreSQL弱密码登录1、在Kali上执行psql -h 192.168.26.129 –U post..._metasploitable2怎么进入
文章浏览阅读257次。本文将为初学者提供Python学习的详细指南,从Python的历史、基础语法和数据类型到面向对象编程、模块和库的使用。通过本文,您将能够掌握Python编程的核心概念,为今后的编程学习和实践打下坚实基础。_python人工智能开发从入门到精通pdf