dreamcoders / laravel-dingbot
a dingtalk robot message handle for send message
v1.0.1
2023-09-01 08:09 UTC
Requires
- php: >=7.0
- guzzlehttp/guzzle: ^6.2|^7.0
README
介绍
企业内部有较多系统支撑着公司的核心业务流程,譬如CRM系统、交易系统、监控报警系统等等。通过钉钉的自定义机器人,可以将这些系统事件同步到钉钉的聊天群。 laravel-dingbot 是一款钉钉机器人消息推送的Laravel扩展,您可以通过此扩展简单高效的推送消息通知到钉钉,进行监控和提醒操作。
钉钉官方文档
安装
composer require dreamcoders/laravel-dingbot
在laravel项目中使用
安装成功后执行
php artisan vendor:publish --provider="DreamCoders\DingBot\DingBotServiceProvider"
会自动将dingbot.php
添加到您项目的config配置文件当中
相关配置
return [ 'webhookUrl' => env('DING_ROBOT_URL', 'https://oapi.dingtalk.com/robot/send'), 'default' => [ // 机器人的access_token default 'access_token' => env('DING_TOKEN','4c8ed2083bcd5cc9d38343211900ea29ef7bbef9156ad0892'), // 加签 (不开启加签则为空) 'secret' => env('DING_SECRET',''), ], 'bot1' => [ // 机器人的access_token bot1 'access_token' => env('DING_TOKEN1',''), // 加签 (不开启加签则为空) 'secret' => env('DING_SECRET1',''), ], 'bot2' => [ // 机器人的access_token bot2 'access_token' => env('DING_TOKEN2',''), // 加签 (不开启加签则为空) 'secret' => env('DING_SECRET2',''), ], ];
钉钉推送access_token
- 钉钉推送链接Webhook:https://oapi.dingtalk.com/robot/send?access_token=you-push-token
- 发送钉钉机器人的token,即在您创建机器人Webhook之后的access_token
.env配置
DING_TOKEN=you-push-token
多机器人配置
如果想要添加多个机器人,则在dingbot.php
当中添加机器人名字和对应的token配置即可
'default' => [ // 机器人的access_token default 'access_token' => env('DING_TOKEN','4c8ed2083bcd5cc9d38343211900ea29ef7bbef9156ad0892'), // 加签 (不开启加签则留空) 'secret' => env('DING_SECRET',''), ], 'bot1' => [ // 机器人的access_token bot1 'access_token' => env('DING_TOKEN1',''), // 加签 (不开启加签则留空) 'secret' => env('DING_SECRET1',''), ], 'bot2' => [ // 机器人的access_token bot2 'access_token' => env('DING_TOKEN2',''), // 加签 (不开启加签则留空) 'secret' => env('DING_SECRET2',''), ]
.env配置
DING_TOKEN=you-push-token DING_TOKEN1=you-push-token
安全配置
自定义关键词
最多可以设置10个关键词,消息中至少包含其中1个关键词才可以发送成功。 例如添加了一个自定义关键词:监控报警,则这个机器人所发送的消息,必须包含监控报警这个词,才能发送成功。
加签
钉钉创建机器人时选择加签,将secret
复制到对应配置文件中即可,如果开启加签方式,则必须填写secret
,否则留空即可
DING_SECRET=you-bot-secret DING_SECRET1=you-bot-secret DING_SECRET2=you-bot-secret
IP地址(段)
设定后,只有来自IP地址范围内的请求才会被正常处理。支持两种设置方式:IP地址和IP地址段,暂不支持IPv6地址白名单
使用示例
发送纯文字消息
Ding()->text("服务器通知报警,请紧急处理")->send();
or
(new DingBot())->text('服务器通知报警,请紧急处理')->send();
发送消息@指定人员
Ding()->text("服务器通知报警,请紧急处理") ->setAtMobiles(['13218899188']) ->send();
发送消息@所有人
Ding()->text("服务器通知报警,请紧急处理") ->setAtAll() ->send();
发送markdown类型的消息
$title = '杭州天气'; $markdown = "#### 杭州天气 \n ". "> 9度,@1825718XXXX 西北风1级,空气良89,相对温度73%\n\n ". "> \n". "> ###### 10点20分发布 [天气](http://www.thinkpage.cn/) "; Ding()->markdown($title,$markdown)->send();
发送消息@指定人员/所有人 同上
发送链接类型的消息
$title = "自定义机器人协议"; $text = "群机器人是钉钉群的高级扩展功能。群机器人可以将第三方服务的信息聚合到群聊中,实现自动化的信息同步。例如:通过聚合GitHub,GitLab等源码管理服务,实现源码更新同步;通过聚合Trello,JIRA等项目协调服务,实现项目信息同步。不仅如此,群机器人支持Webhook协议的自定义接入,支持更多可能性,例如:你可将运维报警提醒通过自定义机器人聚合到钉钉群。"; $picUrl = ""; $messageUrl = "https://open-doc.dingtalk.com/docs/doc.htm?spm=a219a.7629140.0.0.Rqyvqo&treeId=257&articleId=105735&docType=1"; Ding()->link($title,$text,$messageUrl,$picUrl)->send();
发送ActionCard类型的消息
无跳转链接
$title = "乔布斯 20 年前想打造一间苹果咖啡厅,而它正是 Apple Store 的前身"; $text = " \n". " #### 乔布斯 20 年前想打造的苹果咖啡厅 \n\n". " Apple Store 的设计正从原来满满的科技感走向生活化,而其生活化的走向其实可以追溯到 20 年前苹果一个建立咖啡馆的计划"; Ding()->actionCard($title,$text,1)->send();
整体跳转ActionCard类型(single)
$title = "乔布斯 20 年前想打造一间苹果咖啡厅,而它正是 Apple Store 的前身"; $text = " \n". " #### 乔布斯 20 年前想打造的苹果咖啡厅 \n\n". " Apple Store 的设计正从原来满满的科技感走向生活化,而其生活化的走向其实可以追溯到 20 年前苹果一个建立咖啡馆的计划"; Ding()->actionCard($title,$text,1) ->single("阅读全文","https://www.dingtalk.com/") ->send();
独立跳转ActionCard类型(btns)
$title = "乔布斯 20 年前想打造一间苹果咖啡厅,而它正是 Apple Store 的前身"; $text = " \n". " #### 乔布斯 20 年前想打造的苹果咖啡厅 \n\n". " Apple Store 的设计正从原来满满的科技感走向生活化,而其生活化的走向其实可以追溯到 20 年前苹果一个建立咖啡馆的计划"; Ding()->actionCard($title,$text,1) ->addButtons("内容不错","https://www.dingtalk.com/") ->addButtons("不感兴趣","https://www.dingtalk.com/") ->send();
发送FeedCard类型的消息
$linksArray = [ [ "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" ], [ "title"=> "时代的火车向前开3", "messageURL"=> "https://www.dingtalk.com/", "picURL"=> "https://img.alicdn.com/tfs/TB1NwmBEL9TBuNjy1zbXXXpepXa-2400-1218.png" ], [ "title"=> "时代的火车向前开4", "messageURL"=> "https://www.dingtalk.com/", "picURL"=> "https://img.alicdn.com/tfs/TB1NwmBEL9TBuNjy1zbXXXpepXa-2400-1218.png" ] ]; (new DingBot())->feedCard($linksArray)->send(); Ding()->feedCard($linksArray)->send();
多机器人消息发送
Ding('bot1')->text("服务器通知报警,请紧急处理")->send();
or
(new DingBot('bot1'))->text('服务器通知报警,请紧急处理')->send();
其他消息类型同上
enjoy :)