Developer OpenAPI
首页Apifox官网钉钉openAPI
企业微信openAPI
  • openAPI文档
  • 官方文档
首页Apifox官网钉钉openAPI
企业微信openAPI
  • openAPI文档
  • 官方文档
企业内部开发智慧硬件开发第三方应用开发
企业内部开发智慧硬件开发第三方应用开发
  1. 会话分配与消息收发
  • 通讯录管理
    • 成员管理
      • 手机号获取userid
      • 获取成员授权列表
      • 查询成员用户是否已授权
      • 获取选人ticket对应的用户
    • 异步导出接口
      • 导出成员
      • 导出成员详情
      • 导出部门
      • 导出标签成员
      • 获取导出结果
    • 通讯录搜索
      • 通讯录搜索-通讯录单个搜索
      • 通讯录搜索-通讯录批量搜索
    • 通讯录ID转译
      • 上传需要转译的文件
      • 异步通讯录id转译
      • 获取异步任务结果
    • 通讯录userid排序
      POST
  • 客户联系
    • 企业服务人员管理
      • 获取配置了客户联系功能的成员列表
      • 客户联系「联系我」管理-更新企业已配置的「联系我」方式
      • 客户联系「联系我」管理-获取企业已配置的「联系我」方式
      • 客户联系「联系我」管理-删除企业已配置的「联系我」方式
      • 客户联系「联系我」管理-结束临时会话
    • 客户管理
      • 获取客户列表
      • 修改客户备注信息
      • 批量获取客户详情
      • 外部联系人unionid转换
      • 代开发应用external_userid转换
    • 客户标签管理
      • 管理企业标签
        • 管理企业标签-获取企业标签库
        • 管理企业标签-添加企业客户标签
        • 管理企业标签-编辑企业客户标签
        • 管理企业标签-删除企业客户标签
      • 编辑客户企业标签
    • 在职继承
      • 分配在职成员的客户
      • 查询客户接替状态
    • 离职继承
      • 获取待分配的离职成员列表
      • 分配离职成员的客户
      • 查询客户接替状态
      • 分配离职成员的客户群
    • 客户群管理
      • 获取客户群列表
      • 获取客户群详情
      • 客户群opengid转换
    • 客户朋友圈
      • 企业发表内容到客户的朋友圈
        • 企业发表内容到客户的朋友圈-创建发表任务
        • 企业发表内容到客户的朋友圈-获取任务创建结果
      • 获取客户朋友圈全部的发表记录
        • 获取客户朋友圈全部的发表记录-获取企业全部的发表列表
        • 获取客户朋友圈全部的发表记录-获取客户朋友圈企业发表的列表
        • 获取客户朋友圈全部的发表记录-获取客户朋友圈发表时选择的可见范围
        • 获取客户朋友圈全部的发表记录-获取客户朋友圈发表后的可见客户列表
        • 获取客户朋友圈全部的发表记录-获取客户朋友圈的互动数据
    • 消息推送
      • 获取企业的全部群发记录
        • 获取企业的全部群发记录-获取群发记录列表
        • 获取企业的全部群发记录-获取群发成员发送任务列表
        • 获取企业的全部群发记录-获取企业群发成员执行结果
      • 创建企业群发
      • 发送新客户欢迎语
      • 入群欢迎语素材管理-添加
      • 入群欢迎语素材管理-编辑
      • 入群欢迎语素材管理-获取
      • 入群欢迎语素材管理-删除
    • 统计管理
      • 获取「群聊数据统计」数据-按群主聚合的方式
      • 获取「群聊数据统计」数据-按自然日聚合的方式
      • 获取「联系客户统计」数据
    • 管理商品图册
      • 创建商品图册
      • 获取商品图册
      • 删除商品图册
      • 获取商品图册列表
      • 编辑商品图册
    • 管理聊天敏感词
      • 管理聊天敏感词-新建敏感词规则
      • 管理聊天敏感词-获取敏感词规则列表
      • 管理聊天敏感词-获取敏感词规则详情
      • 管理聊天敏感词-修改敏感词规则
      • 管理聊天敏感词 删除敏感词规则
    • 上传附件资源
      POST
  • 家校沟通
    • 基础接口
      • 获取外部联系人详情
      • 发送「学校通知」
      • 获取「学校通知」二维码
      • 管理「学校通知」的关注模式-设置关注「学校通知」的模式
      • 管理「学校通知」的关注模式-获取关注「学校通知」的模式
      • 外部联系人openid转换
      • 获取可使用的家长范围
      • 手机号转外部联系人ID
      • 管理「老师可查看班级」模式-设置「老师可查看班级」的模式
      • 管理「老师可查看班级」模式-获取「老师可查看班级」的模式
    • 学生与家长管理
      • 创建学生
      • 删除学生
      • 更新学生
      • 批量创建学生
      • 批量删除学生
      • 批量更新学生
      • 创建家长
      • 删除家长
      • 更新家长
      • 批量创建家长
      • 批量删除家长
      • 批量更新家长
      • 读取学生或家长
      • 获取部门成员详情
      • 设置家校通讯录自动同步模式
      • 获取部门家长详情
    • 部门管理
      • 创建部门
      • 更新部门
      • 删除部门
      • 获取部门列表
      • 修改自动升年级的配置
  • 微信客服
    • 客服帐号管理
      • 添加客服帐号
      • 删除客服帐号
      • 修改客服帐号
      • 获取客服帐号列表
      • 获取客服帐号链接
    • 接待人员管理
      • 删除接待人员
      • 获取接待人员列表
    • 会话分配与消息收发
      • 分配客服会话
        • 分配客服会话-获取会话状态
        • 分配客服会话-变更会话状态
      • 接收消息和事件-读取消息
        POST
      • 发送消息
        POST
      • 发送欢迎语等事件响应消息
        POST
    • 「升级服务」配置
      • 「升级服务」配置-获取配置的专员与客户群
      • 「升级服务」配置-为客户升级为客户群服务
      • 「升级服务」配置-为客户取消推荐
    • 其他基础信息获取
      • 获取客户基础信息
      • 获取企业状态信息-获取视频号绑定状态
  • 应用管理
    • 设置工作台自定义展示
      • 设置工作台自定义展示-设置应用在工作台展示的模版
      • 设置工作台自定义展示-获取应用在工作台展示的模版
      • 设置工作台自定义展示-设置应用在用户工作台展示的数据
  • 消息推送
    • 撤回应用消息
  • OA
    • 打卡
      • 获取员工打卡规则
      • 获取打卡记录数据
      • 获取打卡日报数据
      • 获取打卡月报数据
      • 获取打卡人员排班信息
      • 为打卡人员排班
      • 获取设备打卡数据
    • 审批
      • 获取审批模板详情
      • 提交审批申请
      • 批量获取审批单号
      • 获取审批申请详情
      • 获取企业假期管理配置
      • 获取成员假期余额
      • 修改成员假期余额
      • 复制/更新模板到企业
  • 效率工具
    • 日程
      • 日历接口
        • 日历接口 创建日历
        • 日历接口 更新日历
        • 日历接口 获取日历详情
        • 日历接口 删除日历
      • 日程接口
        • 日程接口 创建日程
        • 日程接口更新日程
        • 日程接口 获取日程详情
        • 日程接口 取消日程
        • 日程接口 获取日历下的日程列表
    • 会议
      • 创建预约会议
      • 修改预约会议
      • 取消预约会议
      • 获取成员会议ID列表
      • 获取会议详情
    • 直播
      • 创建预约直播
      • 修改预约直播
      • 取消预约直播
      • 在微信中观看直播或直播回放
      • 获取直播详情
      • 获取直播观看明细
      • 获取跳转小程序商城的直播观众信息
  • 家校应用
    • 上课直播
      • 删除直播回放
      • 获取老师直播ID列表
      • 获取直播详情
      • 获取观看直播统计
      • 获取未观看直播统计
    • 班级收款
      • 获取学生付款结果
      • 获取订单详情
  • 企业支付
    • 对外收款
      • 获取对外收款记录
  • 企业互联
    • 获取应用共享信息
  • 上下游
    • 获取应用共享信息
  • 开发指南
    • 企业微信账号ID安全性全面升级
      • 一、企业corpid的升级方案
        • 1.4 corpid转换
      • 二、企业员工userid的升级方案
        • 2.4 userid的转换
      • 三、企业员工external_userid的升级方案
        • 转换external_userid
        • 设置迁移完成
      • 四、企业客户微信unionid的升级方案
        • 4.2 unionid查询external_userid
  • 自建应用代开发
    • 获取带参授权链接
  1. 会话分配与消息收发

接收消息和事件-读取消息

POST
http://127.0.0.1/cgi-bin/kf/sync_msg
第三方应用开发/微信客服/会话分配与消息收发
最后修改时间:2022-08-30 03:03:37
责任人:未设置

概述#

当微信客户、接待人员发消息或有行为动作时,企业微信后台会将事件的回调数据包发送到企业指定URL;企业收到请求后,再通过读取消息接口主动读取具体的消息内容。

回调事件#

接收并解析事件的方法见:接收事件。
示例
<xml>   <ToUserName><![CDATA[ww12345678910]]></ToUserName>   <CreateTime>1348831860</CreateTime>   <MsgType><![CDATA[event]]></MsgType>   <Event><![CDATA[kf_msg_or_event]]></Event>   <Token><![CDATA[ENCApHxnGDNAVNY4AaSJKj4Tb5mwsEMzxhFmHVGcra996NR]]></Token></xml>
说明
参数说明
ToUserName企业微信CorpID
CreateTime消息创建时间,unix时间戳
MsgType消息的类型,此时固定为:event
Event事件的类型,此时固定为:kf_msg_or_event
Token调用拉取消息接口时,需要传此token,用于校验请求的合法性
读取消息
微信客户发送的消息、接待人员在企业微信回复的消息、发送消息接口发送失败事件(如被用户拒收)、客户点击菜单消息的回复消息,可以通过该接口获取具体的消息内容和事件。不支持读取通过发送消息接口发送的消息。
支持的消息类型:文本、图片、语音、视频、文件、位置、链接、名片、小程序、菜单、事件。
权限说明:
企业需要使用“微信客服”secret所获取的accesstoken来调用(accesstoken如何获取?)
第三方应用需具有“微信客服权限->管理帐号、分配会话和收发消息”权限
文档ID: 31078
原文档地址:
https://open.work.weixin.qq.com/api/doc/90000/90135/94670
https://open.work.weixin.qq.com/api/doc/90001/90143/94699

请求参数

Query 参数
access_token
string 
调用接口凭证
必需
示例值:
{{accesstoken}}
Body 参数application/json
cursor
string 
可选
上一次调用时返回的next_cursor,第一次拉取可以不填。 不多于64字节
limit
integer <int32>
可选
期望请求的数据量,默认值和最大值都为1000。 注意:可能会出现返回条数少于limit的情况,需结合返回的has_more字段判断是否继续请求。
token
string 
可选
回调事件返回的token字段,10分钟内有效;可不填,如果不填接口有严格的频率限制。 不多于128字节
示例
{
  "cursor": "4gw7MepFLfgF2VC5npN",
  "token": "ENCApHxnGDNAVNY4AaSJKj4Tb5mwsEMzxhFmHVGcra996NR",
  "limit": 1000
}

示例代码

Shell
JavaScript
Java
Swift
Go
PHP
Python
HTTP
C
C#
Objective-C
Ruby
OCaml
Dart
R
请求示例请求示例
Shell
JavaScript
Java
Swift
curl --location -g --request POST 'http://127.0.0.1/cgi-bin/kf/sync_msg?access_token={{accesstoken}}' \
--header 'Content-Type: application/json' \
--data-raw '{
    "cursor": "4gw7MepFLfgF2VC5npN",
    "token": "ENCApHxnGDNAVNY4AaSJKj4Tb5mwsEMzxhFmHVGcra996NR",
    "limit": 1000
}'

返回响应

🟢200成功
application/json
Body
errcode
integer <int32>
可选
msg_list
array [object {7}] 
消息列表
可选
external_userid
string 
可选
客户UserID(msgtype为event,该字段不返回)
send_time
integer <int32>
消息发送时间
可选
origin
integer <int32>
可选
消息来源。3-微信客户发送的消息 4-系统推送的事件消息 5-接待人员在企业微信客户端发送的消息
msgid
string 
消息ID
可选
servicer_userid
string 
可选
从企业微信给客户发消息的客服人员userid(msgtype为event,该字段不返回)
open_kfid
string 
可选
客服帐号ID(msgtype为event,该字段不返回
msgtype
string 
可选
对不同的msgtype,有相应的结构描述,下面进一步说明
next_cursor
string 
可选
下次调用带上该值,则从当前的位置继续往后拉,以实现增量拉取。 强烈建议对改该字段入库保存,每次请求读取带上,请求结束后更新。避免因意外丢,导致必须从头开始拉取,引起消息延迟。
errmsg
string 
可选
has_more
integer <int32>
可选
是否还有更多数据。0-否;1-是。 不能通过判断msg_list是否空来停止拉取,可能会出现has_more为1,而msg_list为空的情况
示例
{
  "errcode": 0,
  "msg_list": [
    {
      "external_userid": "string",
      "send_time": 0,
      "origin": 0,
      "msgid": "string",
      "servicer_userid": "string",
      "open_kfid": "string",
      "msgtype": "string"
    }
  ],
  "next_cursor": "string",
  "errmsg": "string",
  "has_more": 0
}
上一页
分配客服会话-变更会话状态
下一页
发送消息
Built with