三步搭建“钉钉待办推送” (curl版)+工作通知

三步搭建"钉钉待办推送" (curl版)



第一部:搞定"通行证" (配置应用)

想调用接口,得先有个"身份"。

  1. 创建应用
    • 登录 钉钉开放平台 -> 应用开发 -> 企业内部开发
    • 创建钉钉新应用
  2. 拿钥匙 (Key & Secret)
    • "凭证与基础信息" 里,复制 AppKeyAppSecret
    • 这是你的账号密码,保存好。
  3. 开权限 (必做)
    • 左侧 "权限管理" ,搜索并申请:待办任务写权限 (todo.task:write)。
    • 没这个权限,接口会直接报错。
  4. 设范围 (巨坑预警)
    • 左侧 "版本管理与发布" -> "设置可见范围"
    • 一定要把"你自己"选进去!
    • 不选的话,应用就是"瞎子",查不到你的信息。

第二部:锁定"目标人物" (获取 UnionId)

这是最关键的一步。钉钉推待办只认 unionId。我们分两步走:先在网页上看你的 UserID,再换成 UnionId。

1. 拿到 AccessToken (临时令牌)

所有接口都得带这个 Token。打开终端(CMD/Terminal),替换你的 Key 和 Secret:

复制代码
curl "https://oapi.dingtalk.com/gettoken?appkey=你的AppKey&appsecret=你的AppSecret"

复制结果里的 access_token,下一步要用。

2. 找到你的 UserID (直观方案)

不用调复杂接口,直接去管理员后台看。

  • 地址https://oa.dingtalk.com/contacts.htm#/contacts
  • 操作 :在通讯录里点击你的名字,在右侧弹出的详情页里,找到 UserID(通常在"员工UserID"这一栏,或者看浏览器地址栏最后一段)。
  • 记下这个 UserID(例如 011645...)。

3. 用 UserID 换 UnionId (关键转换)

因为 UserID 不能直接发待办,我们需要用它换取 UnionId。运行下面命令:

复制代码
curl --location --request POST 'https://oapi.dingtalk.com/topapi/v2/user/get?access_token=刚才拿到的Token' \
--header 'Content-Type: application/json' \
--data-raw '{
    "userid": "刚才后台看到的UserID"
}'

返回结果:找到 result 里的 unionid (例如 ZYR7...)。

这就是你的终极"身份证",记下来!
(备选方案:如果你进不去管理员后台,也可以用 v1.0/contact/users/getByMobile 接口通过手机号反查,这里不展开。)


第三部:发射!(推送待办)

万事俱备,直接通过命令行发起待办任务。我们使用最新的 v1.0 接口。

修改参数

  • YOUR_TOKEN: 第二部第1步拿到的 Token。
  • YOUR_UNION_ID: 第二部第3步拿到的 UnionId。

执行命令

复制代码
curl --location --request POST 'https://api.dingtalk.com/v1.0/todo/users/YOUR_UNION_ID/tasks' \
--header 'x-acs-dingtalk-access-token: YOUR_TOKEN' \
--header 'Content-Type: application/json' \
--data-raw '{
    "sourceId": "CURL_DEMO_001", 
    "subject": "【测试】这是一个Curl发出的待办",
    "description": "不用写代码,命令行直接把任务推送到手机。",
    "dueTime": 1735660800000,
    "executorIds": ["YOUR_UNION_ID"],
    "isOnlyShowExecutor": true,
    "detailUrl": {
        "appUrl": "https://www.dingtalk.com",
        "pcUrl": "https://www.dingtalk.com"
    },
    "priority": 20
}'

见证奇迹:

回车敲下的瞬间,你的手机钉钉会弹出一条 "待办任务" 通知。点击它,会跳转到钉钉官网。


晚上更新,工作通知推送

bash 复制代码
curl -X POST "https://oapi.dingtalk.com/topapi/message/corpconversation/asyncsend_v2?access_token=8a9d0dce49****a960ca14d8dd8f25" \
-H 'Content-Type: application/json' \
-d '{
    "agent_id": 413638***8,
    "userid_list": "011*****101231766",
    "msg": {
        "msgtype": "text",
        "text": {
            "content": "【工作通知】\n你好***,接口调试成功!\n这是来自curl的测试消息666。"
        }
    }
}'

注意点,两次同样的内容会被拦截

相关推荐
网硕互联的小客服2 小时前
哪些外在因素条件会导致服务器的延迟过高?
linux·运维·服务器·数据库·安全
打不了嗝 ᥬ᭄2 小时前
【MySQL】表的约束与基本查询
数据库·mysql
无心水2 小时前
【神经风格迁移:性能】24、神经风格迁移全链路监控实战:基于Prometheus+Grafana的性能调优指南
数据库·人工智能·深度学习·机器学习·grafana·prometheus·神经风格迁移:性能
佳瑞Jarrett2 小时前
我用 Vue + SpringBoot + Redis 写了个「文件快取柜」
vue.js·spring boot·redis
augisTrench2 小时前
LatentFlowx是一种非令牌的、状态驱动的推理运行时,旨在通过以下方式降低计算成本并提高可控性
数据库
橘子真甜~2 小时前
Reids命令原理与应用2 - Redis网络层与优化,pipeline,发布订阅与事务
数据库·redis·缓存·事务·发布订阅·lua脚本·acid特性
源代码•宸2 小时前
goframe框架签到系统项目开发(用户认证中间件、实现Refresh-token接口)
数据库·经验分享·后端·算法·中间件·跨域·refreshtoken
建群新人小猿2 小时前
陀螺匠 企业助手-经我审批
服务器·数据库·php
TDengine (老段)2 小时前
TDengine 小白入门指南
大数据·数据库·物联网·时序数据库·tdengine·涛思数据