1. 程式人生 > 程式設計 >java實現釘釘機器人訊息推送的示例程式碼

java實現釘釘機器人訊息推送的示例程式碼

先建個釘釘群,並加好機器人

在這裡插入圖片描述

在這裡插入圖片描述

在這裡插入圖片描述

在這裡插入圖片描述

在這裡插入圖片描述

在這裡插入圖片描述

此時,機器人已經新增完畢,接下來編寫我們連線機器人小哥的程式碼

import com.alibaba.fastjson.JSON;
import com.google.common.collect.Lists;
import com.google.common.collect.Maps;
import java.util.List;
import java.util.Map;

/**
 * @author yanghao
 * @version DingTalkTest.java,v 0.1 2019-03-29 11:36
 */
public class DingTalkTest {

 public static void main(String[] args){

 try {
  //釘釘機器人地址(配置機器人的webhook)
  String dingUrl = "https://oapi.dingtalk.com/robot/send?access_token=............";

  //是否通知所有人
  boolean isAtAll = false;
  //通知具體人的手機號碼列表
  List<String> mobileList = Lists.newArrayList();

  //釘釘機器人訊息內容
  String content = "小哥,你好!";
  //組裝請求內容
  String reqStr = buildReqStr(content,isAtAll,mobileList);

  //推送訊息(http請求)
  String result = HttpUtil.postJson(dingUrl,reqStr);
  System.out.println("result == " + result);

 }catch (Exception e){
  e.printStackTrace();

 }

 }

 /**
 * 組裝請求報文
 * @param content
 * @return
 */
 private static String buildReqStr(String content,boolean isAtAll,List<String> mobileList) {
 //訊息內容
 Map<String,String> contentMap = Maps.newHashMap();
 contentMap.put("content",content);

 //通知人
 Map<String,Object> atMap = Maps.newHashMap();
 //1.是否通知所有人
 atMap.put("isAtAll",isAtAll);
 //2.通知具體人的手機號碼列表
 atMap.put("atMobiles",mobileList);

 Map<String,Object> reqMap = Maps.newHashMap();
 reqMap.put("msgtype","text");
 reqMap.put("text",contentMap);
 reqMap.put("at",atMap);

 return JSON.toJSONString(reqMap);
 }

}

執行結果如下:

result == {"errmsg":"ok","errcode":0}

釘釘群顯示訊息:

在這裡插入圖片描述

ok,簡單的訊息推送,這就完成了!

我們再來測試一下通知所有人和通知具體人

將isAtAll更改為true

//是否通知所有人
boolean isAtAll = true;
//通知具體人的手機號碼列表
List<String> mobileList = Lists.newArrayList();

在這裡插入圖片描述

增加通知人號碼列表(注:isAtAll和mobileList 不能同時生效)

//是否通知所有人
boolean isAtAll = false;
//通知具體人的手機號碼列表
List<String> mobileList = Lists.newArrayList();
mobileList.add("182********");

在這裡插入圖片描述

再來測試一下特殊符號

換行識別符號

/**
 * 換行識別符號
 */
private static final String NEWLINE = "\n";

//釘釘機器人訊息內容
//String content = "小哥,你好!";
StringBuffer sb = new StringBuffer();
sb.append("小哥,你好!")
 .append(NEWLINE)
 .append("看會書");

String content = sb.toString();

在這裡插入圖片描述

emoji圖片

先獲取emoji圖片的unicode編碼

在這裡插入圖片描述

編寫程式碼如下:

/**
 * 蘋果unicode編碼
 */
private static final String APPLE = "\ud83c\udf4e";

//釘釘機器人訊息內容
//String content = "小哥,你好!";
StringBuffer sb = new StringBuffer();
sb.append("小哥,你好!")
 .append(NEWLINE)
 .append("看會書")
 .append(NEWLINE)
 .append("吃個").append(APPLE);

String content = sb.toString();

在這裡插入圖片描述

通常在我們的專案中,作為一些告警加入,方便且實用
很有意思的釘釘機器人,很多實用技巧,可以深入去探索一波!

更新於2019-12-05

很多小夥伴留言諮詢http請求,這邊給大家2個http請求程式碼

1. maven專案

新增依賴

<!--糊塗工具-->
<dependency>
 <groupId>cn.hutool</groupId>
 <artifactId>hutool-all</artifactId>
 <version>4.0.12</version>
</dependency>

http請求程式碼

private static final int timeout = 10000; 

public static String postJson(String url,String reqStr) {
 String body = null;
 try {
  body = HttpRequest.post(url).body(reqStr).timeout(timeout).execute().body();
 } catch (Exception e) {
  e.printStackTrace();
 }
 return body;
}

2. 非maven專案

新增jar包
httpclient-xxx.jar
commons-logging-xxx.jar

http請求程式碼

public static String postJson(String url,String body) {
  // 建立Httpclient物件
  CloseableHttpClient httpClient = createCustomClient();
  CloseableHttpResponse response = null;
  String resultString = null;
  try {
   // 建立Http Post請求
   HttpPost httpPost = new HttpPost(url);
   httpPost.addHeader("Content-Type","application/json");

   if (body != null) {
    httpPost.setEntity(new StringEntity(body,"utf-8"));
   }
   // 執行http請求
   response = httpClient.execute(httpPost);
   resultString = EntityUtils.toString(response.getEntity(),"utf-8");
  } catch (Exception e) {
   e.printStackTrace();
  } finally {
   try {
    if (response != null) {
     response.close();
    }
   } catch (Exception e) {
    e.printStackTrace();
   }
  }

  return resultString;
 }

 public static CloseableHttpClient createCustomClient() {
  RequestConfig defaultRequestConfig = RequestConfig.custom()
    .setSocketTimeout(120 * 1000)
    .setConnectTimeout(120 * 1000)
    .setConnectionRequestTimeout(120 * 1000)
    .setStaleConnectionCheckEnabled(true)
    .build();

  return HttpClients.custom().setDefaultRequestConfig(defaultRequestConfig).build();
 }

方法僅供參考,專案裡面有現成的http請求,可以直接用!

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支援我們。