目录
- 设置与接入
- 发送消息
设置与接入
1、创建一个钉钉群
2、打开群设置,智能群助手,添加机器人,自定义Webhook接入
3、设置机器人名字,开启消息推送,复制Webhook地址
4、安全设置,选择自定义关键词,最多可添加十个
发送消息
采用post方式向上面复制的地址发送请求即可
消息协议:https://open.dingtalk.com/document/robots/message-types-and-data-format
/*
-- @Time : 2022/6/8 11:24
-- @Author : raoxiaoya
-- @Desc :
*/
package dingtalk
import (
"encoding/json"
"errors"
"voteapi/pkg/curl"
)
type Response struct {
Errcode int
Errmsg string
}
const KeywordMonitor = "Monitor"
const MessageRobot = "https://oapi.dingtalk.com/robot/send?access_token=xxxxxxxxxxxxxxxxxxxx"
// 发送简单文本消息
func SendDingTalkMessage(messageContent, messagePrefix string) (err error) {
defer func() {
if er := recover(); er != nil {
err = errors.New("SendDingTalkMessage panic")
}
}()
headers := map[string]string{
"Content-Type": "application/json",
}
text := map[string]string{
"content": messagePrefix + ": " + messageContent,
}
postData := map[string]interface{}{
"msgtype": "text",
"text": text,
}
body, _ := json.Marshal(postData)
resp, err := curl.HttpRequest(MessageRobot, "POST", headers, string(body))
if err != nil {
return err
}
var re Response
_ = json.Unmarshal([]byte(resp), &re)
if re.Errcode > 0 {
return errors.New(resp)
}
return nil
}
调用
dingtalk.SendDingTalkMessage(fmt.Sprintf("service [%s] reboot success", v.Name), dingtalk.KeywordMonitor)
声明:本站所有文章,如无特殊说明或标注,均为本站原创发布。任何个人或组织,在未征得本站同意时,禁止复制、盗用、采集、发布本站内容到任何网站、书籍等各类媒体平台。如若本站内容侵犯了原著者的合法权益,可联系我们进行处理。

评论(0)