• 钉钉机器人消息推送composer拓展 laravel-dingbot


    钉钉机器人消息发送

    介绍

    企业内部有较多系统支撑着公司的核心业务流程,譬如CRM系统、交易系统、监控报警系统等等。通过钉钉的自定义机器人,可以将这些系统事件同步到钉钉的聊天群。 laravel-dingbot 是一款钉钉机器人消息推送的Laravel扩展,您可以通过此扩展简单高效的推送消息通知到钉钉,进行监控和提醒操作。

    钉钉官方文档

    安装

    composer require dreamcoders/laravel-dingbot

    在laravel项目中使用

    安装成功后执行

    php artisan vendor:publish --provider="DreamCoders\DingBot\DingBotServiceProvider"

    会自动将dingbot.php添加到您项目的config配置文件当中

    相关配置

    1. return [
    2. 'webhookUrl' => env('DING_ROBOT_URL', 'https://oapi.dingtalk.com/robot/send'),
    3. 'default' => [
    4. // 机器人的access_token default
    5. 'access_token' => env('DING_TOKEN','4c8ed2083bcd5cc9d38343211900ea29ef7bbef9156ad0892'),
    6. // 加签 (不开启加签则为空)
    7. 'secret' => env('DING_SECRET',''),
    8. ],
    9. 'bot1' => [
    10. // 机器人的access_token bot1
    11. 'access_token' => env('DING_TOKEN1',''),
    12. // 加签 (不开启加签则为空)
    13. 'secret' => env('DING_SECRET1',''),
    14. ],
    15. 'bot2' => [
    16. // 机器人的access_token bot2
    17. 'access_token' => env('DING_TOKEN2',''),
    18. // 加签 (不开启加签则为空)
    19. 'secret' => env('DING_SECRET2',''),
    20. ],
    21. ];

    钉钉推送access_token

    .env配置

    DING_TOKEN=you-push-token

    多机器人配置

    如果想要添加多个机器人,则在dingbot.php当中添加机器人名字和对应的token配置即可

    1. 'default' => [
    2. // 机器人的access_token default
    3. 'access_token' => env('DING_TOKEN','4c8ed2083bcd5cef9156ad0892'),
    4. // 加签 (不开启加签则留空)
    5. 'secret' => env('DING_SECRET',''),
    6. ],
    7. 'bot1' => [
    8. // 机器人的access_token bot1
    9. 'access_token' => env('DING_TOKEN1',''),
    10. // 加签 (不开启加签则留空)
    11. 'secret' => env('DING_SECRET1',''),
    12. ],
    13. 'bot2' => [
    14. // 机器人的access_token bot2
    15. 'access_token' => env('DING_TOKEN2',''),
    16. // 加签 (不开启加签则留空)
    17. 'secret' => env('DING_SECRET2',''),
    18. ]

    .env配置

    1. DING_TOKEN=you-push-token
    2. DING_TOKEN1=you-push-token

    安全配置

    自定义关键词

    最多可以设置10个关键词,消息中至少包含其中1个关键词才可以发送成功。 例如添加了一个自定义关键词:监控报警,则这个机器人所发送的消息,必须包含监控报警这个词,才能发送成功。

    加签

    钉钉创建机器人时选择加签,将secret复制到对应配置文件中即可,如果开启加签方式,则必须填写secret,否则留空即可

    1. DING_SECRET=you-bot-secret
    2. DING_SECRET1=you-bot-secret
    3. DING_SECRET2=you-bot-secret

    IP地址(段)

    设定后,只有来自IP地址范围内的请求才会被正常处理。支持两种设置方式:IP地址和IP地址段,暂不支持IPv6地址白名单

    使用示例

    发送纯文字消息

    Ding()->text("服务器通知报警,请紧急处理")->send();

    or

    (new DingBot())->text('服务器通知报警,请紧急处理')->send();

    发送消息@指定人员

    1. Ding()->text("服务器通知报警,请紧急处理")
    2. ->setAtMobiles(['13218899188'])
    3. ->send();

    发送消息@所有人

    1. Ding()->text("服务器通知报警,请紧急处理")
    2. ->setAtAll()
    3. ->send();

    发送markdown类型的消息

    1. $title = '杭州天气';
    2. $markdown = "#### 杭州天气 \n ".
    3. "> 9度,@1825718XXXX 西北风1级,空气良89,相对温度73%\n\n ".
    4. "> ![screenshot](http://i01.lw.aliimg.com/media/lALPBbCc1ZhJGIvNAkzNBLA_1200_588.png)\n".
    5. "> ###### 10点20分发布 [天气](http://www.thinkpage.cn/) ";
    6. Ding()->markdown($title,$markdown)->send();

    发送消息@指定人员/所有人 同上

    发送链接类型的消息

    1. $title = "自定义机器人协议";
    2. $text = "群机器人是钉钉群的高级扩展功能。群机器人可以将第三方服务的信息聚合到群聊中,实现自动化的信息同步。例如:通过聚合GitHub,GitLab等源码管理服务,实现源码更新同步;通过聚合Trello,JIRA等项目协调服务,实现项目信息同步。不仅如此,群机器人支持Webhook协议的自定义接入,支持更多可能性,例如:你可将运维报警提醒通过自定义机器人聚合到钉钉群。";
    3. $picUrl = "";
    4. $messageUrl = "https://open-doc.dingtalk.com/docs/doc.htm?spm=a219a.7629140.0.0.Rqyvqo&treeId=257&articleId=105735&docType=1";
    5. Ding()->link($title,$text,$messageUrl,$picUrl)->send();

    发送ActionCard类型的消息

    无跳转链接

    1. $title = "乔布斯 20 年前想打造一间苹果咖啡厅,而它正是 Apple Store 的前身";
    2. $text = "![screenshot](@lADOpwk3K80C0M0FoA) \n".
    3. " #### 乔布斯 20 年前想打造的苹果咖啡厅 \n\n".
    4. " Apple Store 的设计正从原来满满的科技感走向生活化,而其生活化的走向其实可以追溯到 20 年前苹果一个建立咖啡馆的计划";
    5. Ding()->actionCard($title,$text,1)->send();

    整体跳转ActionCard类型(single)

    1. $title = "乔布斯 20 年前想打造一间苹果咖啡厅,而它正是 Apple Store 的前身";
    2. $text = "![screenshot](@lADOpwk3K80C0M0FoA) \n".
    3. " #### 乔布斯 20 年前想打造的苹果咖啡厅 \n\n".
    4. " Apple Store 的设计正从原来满满的科技感走向生活化,而其生活化的走向其实可以追溯到 20 年前苹果一个建立咖啡馆的计划";
    5. Ding()->actionCard($title,$text,1)
    6. ->single("阅读全文","https://www.dingtalk.com/")
    7. ->send();

    独立跳转ActionCard类型(btns)

    1. $title = "乔布斯 20 年前想打造一间苹果咖啡厅,而它正是 Apple Store 的前身";
    2. $text = "![screenshot](@lADOpwk3K80C0M0FoA) \n".
    3. " #### 乔布斯 20 年前想打造的苹果咖啡厅 \n\n".
    4. " Apple Store 的设计正从原来满满的科技感走向生活化,而其生活化的走向其实可以追溯到 20 年前苹果一个建立咖啡馆的计划";
    5. Ding()->actionCard($title,$text,1)
    6. ->addButtons("内容不错","https://www.dingtalk.com/")
    7. ->addButtons("不感兴趣","https://www.dingtalk.com/")
    8. ->send();

    发送FeedCard类型的消息

    1. $linksArray = [
    2. [
    3. "title"=> "时代的火车向前开1通知",
    4. "messageURL"=> "https://www.dingtalk.com/",
    5. "picURL"=> "https://img.alicdn.com/tfs/TB1NwmBEL9TBuNjy1zbXXXpepXa-2400-1218.png"
    6. ],
    7. [
    8. "title"=> "时代的火车向前开2",
    9. "messageURL"=> "https://www.dingtalk.com/",
    10. "picURL"=> "https://img.alicdn.com/tfs/TB1NwmBEL9TBuNjy1zbXXXpepXa-2400-1218.png"
    11. ],
    12. [
    13. "title"=> "时代的火车向前开3",
    14. "messageURL"=> "https://www.dingtalk.com/",
    15. "picURL"=> "https://img.alicdn.com/tfs/TB1NwmBEL9TBuNjy1zbXXXpepXa-2400-1218.png"
    16. ],
    17. [
    18. "title"=> "时代的火车向前开4",
    19. "messageURL"=> "https://www.dingtalk.com/",
    20. "picURL"=> "https://img.alicdn.com/tfs/TB1NwmBEL9TBuNjy1zbXXXpepXa-2400-1218.png"
    21. ]
    22. ];
    23. (new DingBot())->feedCard($linksArray)->send();
    24. Ding()->feedCard($linksArray)->send();

    多机器人消息发送

    Ding('bot1')->text("服务器通知报警,请紧急处理")->send();

    or

    (new DingBot('bot1'))->text('服务器通知报警,请紧急处理')->send();

    其他消息类型同上

    效果示例

  • 相关阅读:
    MyBatis 插件机制详解
    数据结构作业4-图
    RPC vs. HTTP:谁主沉浮在网络通信的江湖?
    HANA:计算视图-图形化Aggregation组件-踩坑小记(注意事项)
    2.DApp-编写和运行solidity智能合约
    TCP三次握手四次分手不一样的解释
    Go数据库操作插件-xorm
    竞赛 题目:基于深度学习的图像风格迁移 - [ 卷积神经网络 机器视觉 ]
    京东云硬钢阿里云:承诺再低10%
    C语言:文件操作
  • 原文地址:https://blog.csdn.net/qq_31766533/article/details/132634390