钉钉发布工作通知

部署运行你感兴趣的模型镜像
public interface DingTalkService {

    /**
     * 工作通知--发送会议通知到钉钉
     * @param useridList
     * @param content
     */
    ResponseVo<Object> notice(String useridList, String content);

    /**
     * 查询钉钉推送消息结果, 仅支持查询24小时内的任务。
     * @param taskId 发送消息时钉钉返回的任务ID
     * @return
     */
    ResponseVo<Object> getNoticeResult(Long taskId);

}

@Service
public class DingTalkServiceImpl implements DingTalkService {

    private static final Logger logger = LoggerFactory.getLogger(DingTalkService.class);

/**
 * 发送钉钉工作通知
 * @param useridList 用户id
 * useridList 最长支持100个用户ID; user123,user456
 * @param content 推送内容
 * @return
 */
@Override
public ResponseVo<Object> notice(String useridList, String content) {
    if(StringUtils.isEmpty(useridList)){
        return  ResponseVo.fail("发送失败,用户ID不能为空!");
    }
    ExternalAccessConfig config = getSystemConfig();
    if (null == config){
        logger.error("发送失败,获取系统配置参数失败!");
        return ResponseVo.fail("发送失败,获取系统配置参数失败!");
    }
    String access_token = DingTalkAccessUtil.getToken(config.getExtAppId(), config.getExtSecret());
    if(StringUtil.isEmpty(access_token)){
        logger.error("不合法的appKey或appSecret");
        return ResponseVo.fail("发送失败,不合法的appKey或appSecret!");
    }

    DingTalkClient client = new DefaultDingTalkClient(DingTalkAccessUtil.POST_NOTICE_URI);
    OapiMessageCorpconversationAsyncsendV2Request request = new OapiMessageCorpconversationAsyncsendV2Request();
    request.setAgentId(Long.parseLong(config.getExtAgentId()));//必填
    request.setUseridList(useridList);//必填
    request.setToAllUser(false);

    OapiMessageCorpconversationAsyncsendV2Request.Msg msg = new OapiMessageCorpconversationAsyncsendV2Request.Msg();
    msg.setMsgtype("text");//推送文本消息
    msg.setText(new OapiMessageCorpconversationAsyncsendV2Request.Text());
    msg.getText().setContent(content);//消息内容,最长不超过2048个字节
    request.setMsg(msg);
    OapiMessageCorpconversationAsyncsendV2Response rsp = null;
    try {
        rsp = client.execute(request, access_token);
        logger.info("钉钉发送工作通知结果:{}", rsp.getBody());
    } catch (ApiException e) {
        e.printStackTrace();
    }
    return ResponseVo.success();
}

@Override
public ResponseVo<Object> getNoticeResult(Long taskId){
    ExternalAccessConfig config = getSystemConfig();
    if (null == config){
        logger.error("发送失败,获取系统配置参数失败!");
        return ResponseVo.fail("发送失败,获取系统配置参数失败!");
    }
    String access_token = DingTalkAccessUtil.getToken(config.getExtAgentId(), config.getExtSecret());
    if(StringUtil.isEmpty(access_token)){
        logger.error("不合法的appKey或appSecret");
        return ResponseVo.fail("发送失败,不合法的appKey或appSecret!");
    }

    DingTalkClient client = new DefaultDingTalkClient("https://oapi.dingtalk.com/topapi/message/corpconversation/getsendresult");
    OapiMessageCorpconversationGetsendresultRequest req = new OapiMessageCorpconversationGetsendresultRequest();
    req.setAgentId(Long.parseLong(config.getExtAgentId()));
    req.setTaskId(taskId);//发送消息时钉钉返回的任务ID, 仅支持查询24小时内的任务。
    OapiMessageCorpconversationGetsendresultResponse rsp = null;
    try {
        rsp = client.execute(req, access_token);
        logger.info("查询通知发送结果:{}", rsp.getBody());
    } catch (ApiException e) {
        e.printStackTrace();
    }
    return ResponseVo.success();

}
/**
 * 批量发送消息,上限100
 * @param sendAddress
 */
private void batchNotice(String sendAddress, String message){
    List<String> list = Arrays.asList(sendAddress.split(","));
    if(!list.isEmpty() && list.size() > 0){
        for (int i = 1; i <= list.size() / 100 + 1; i++) {
            List<String> userList =  listPage(i, 100, list);
            if(!userList.isEmpty() && userList.size() > 0){
                String userIdList = getUserIdListStr(userList);
                this.notice(userIdList, message);
            }
        }
    }
}

}

您可能感兴趣的与本文相关的镜像

ACE-Step

ACE-Step

音乐合成
ACE-Step

ACE-Step是由中国团队阶跃星辰(StepFun)与ACE Studio联手打造的开源音乐生成模型。 它拥有3.5B参数量,支持快速高质量生成、强可控性和易于拓展的特点。 最厉害的是,它可以生成多种语言的歌曲,包括但不限于中文、英文、日文等19种语言

钉钉中发送群通知是群组管理的重要功能之一,钉钉提供了多种方式实现群通知的发送,包括群机器人通知、群内直接发送消息以及通过自定义开发接口推送消息等。 ### 群机器人通知 钉钉群机器人是一种自动发送消息的工具,适用于需要定时自动向群内发送消息的场景,比如定时推送日报、系统告警等。设置方法如下: 1. 打开钉钉群聊,点击右上角的“群设置”。 2. 进入“智能群助手”“机器人”设置页面。 3. 点击“添加机器人”,选择需要的机器人类型,例如“自定义机器人”。 4. 设置机器人名称和头像,获取Webhook地址。 5. 通过调用该Webhook地址并发送指定格式的消息体,即可实现消息推送[^1]。 ### 群公告通知 钉钉群公告是群管理员向全体成员发布重要信息的方式,具有较高的可见性。发送群公告的步骤如下: 1. 在群聊界面点击右上角的“...”按钮。 2. 选择“发布公告”选项。 3. 编辑公告标题和内容,选择是否需要群成员确认阅读。 4. 点击“发布”按钮即可发送公告。 ### 群通知设置方法 钉钉允许用户对群通知进行个性化设置,包括消息提醒方式、免打扰时间段等。具体设置步骤如下: 1. 打开钉钉群聊,点击右上角的“...”按钮。 2. 进入“群聊设置”页面。 3. 可以选择开启关闭“消息免打扰”功能。 4. 对于群管理员,还可以设置群成员的消息发送权限等[^1]。 ### 示例代码:Java发送FeedCard类型消息 如果希望通过编程方式发送更复杂的消息格式,例如FeedCard类型的消息,可以参考以下Java代码示例: ```java public static void sendFeedCardMsg(List<Map<String, String>> linksList) throws Exception { String dingUrl = getDingUrl(); // 获取钉钉机器人Webhook地址 String reqStr = buildReqFeedCard(linksList); // 构建请求数据 String result = HttpRequest.post(dingUrl).body(reqStr).execute().body(); // 发送POST请求 handleErrorCode(result); // 处理错误码 logger.info("钉钉请求发送成功,返回结果:" + result); } private static String buildReqFeedCard(List<Map<String, String>> linksList) { Map<String, Object> feedCardMap = Maps.newHashMap(); feedCardMap.put("links", linksList); // 设置链接列表 Map<String, Object> reqMap = Maps.newHashMap(); reqMap.put("msgtype", "feedCard"); // 设置消息类型为feedCard reqMap.put("feedCard", feedCardMap); // 添加feedCard内容 return JSONObject.toJSONString(reqMap); // 转换为JSON字符串 } ``` 通过上述方法,可以灵活地在钉钉中发送和管理群通知,满足同场景下的需求。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值