钉钉媒体文件上传
最近一个项目需要在钉钉中导出excel。钉钉的文件导出都是工作通知的形式导出。工作通知只能附带媒体文件(media,钉钉自定义的说法),所以采取的策略是先在服务端生成要导出的excel文件,在通过钉钉上传媒体文件接口生成媒体文件,然后通过钉钉的工作通知下发给用户。中间被上传媒体文件接口卡了半天,记录一下,也希望能帮助到遇到相同问题的同行。最后吐槽下钉钉的文档写的是真的简略。
回到正题,首先来看钉钉的文档。
对数据格式和文件名称都有要求。这个media参数是重点。
最开始的时候是直接用的php的curl做post请求,代码如下,其中'Content-Type: application/json; charset=utf-8'设置为了multipart/form-data;,$data就是上面的media,但是钉钉的接口返回提示是参数类型不符合要求。
这就让人纳闷了。在网上查询了下,貌似钉钉的意思是要手动拼接form-data数据,然后传给他。在网上看了下各种写法,最后翻了下sdk的源码,找到上传文件的地方,研究了下,根据sdk的源码稍微微调了下,最后成功把文件上传到钉钉了。
下面这张图里面的$delimiter变量是分割符,$file是文件,用file_get_contents读取。
从上面的图可以看到是有个专门的函数拼接数据的,这就是这次的重点。放下面
sdk里面是写了多参数的循环处理,我这只用上传图片就给简化了,只写了一个文件上传,现在可以看到,为啥钉钉会说你参数类型不对了,因为人家根本就不读你的header头。name=media ,filename就是你要上传的文件。
拼接完后按照正常的curl发出个post请求,搞定。
文件上传的post请求也贴下,还是给设置了header头。
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】凌霞软件回馈社区,博客园 & 1Panel & Halo 联合会员上线
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】博客园社区专享云产品让利特惠,阿里云新客6.5折上折
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· .NET Core 托管堆内存泄露/CPU异常的常见思路
· PostgreSQL 和 SQL Server 在统计信息维护中的关键差异
· C++代码改造为UTF-8编码问题的总结
· DeepSeek 解答了困扰我五年的技术问题
· 为什么说在企业级应用开发中,后端往往是效率杀手?
· 清华大学推出第四讲使用 DeepSeek + DeepResearch 让科研像聊天一样简单!
· 推荐几款开源且免费的 .NET MAUI 组件库
· 实操Deepseek接入个人知识库
· 易语言 —— 开山篇
· Trae初体验