# 消息类型与数据格式

注意

关于 markdown 的解析工作使用的库为 marked,不同解析库的解析结果会有细微的差异,为确保 markdown 消息发送后解析效果达到预期,请在发送之前使用 demo page 进行效果测试。

# 1、文本消息:

{
    "msgtype": "text",
    "text": {
        "content": "你就是你, @150XXXXXXXX 璀璨的烟火"
    },
     "at": {
         "atMobiles": [
             "150********",
             "186********"
         ],
         "atWorkCodes": [
             "171765"
         ],
         "isAtAll": false
     }
}
参数 参数类型 必须 说明
msgtype String 消息类型,此时固定为:text【只有text、markdown类型的消息支持@】
content String 消息内容,限制5000字符以内
atMobiles list 被@人的手机号列表,手机号必须是合法的手机号
atWorkCodes list 被@人的工号列表
isAtAll boolean @所有人是true,否则为false

# 2、markdown消息

注意事项:text字段里的链接为yach://yach.zhiyinlou.com/session/webview?url=这里放上接入方的跳转地址,记得提前url_encode编码一下

示例:yach://yach.zhiyinlou.com/session/webview?url=https%3a%2f%2fyach.zhiyinlou.com 如果PC端想要通过侧边栏打开的话,需要在上面的url链接后面,加上【pc_slide=true】

示例:yach://yach.zhiyinlou.com/session/webview?url=https%3a%2f%2fyach.zhiyinlou.com&pc_slide=true

评价消息的示例:yach://yach.zhiyinlou.com/session/robot?extra=%7B%22click%22:1%7D&type=appraise&nonce=1

消息回显:需要在上面链接的后面,新增【reply】参数把回显内容传过来,示例如下:

示例:yach://yach.zhiyinlou.com/session/robot?extra=%7B%22click%22:1%7D&reply=回显内容

为了防止一些图片在展示的时候发生闪动的现象,用户可以自己设定图片的宽高,按照如下格式设置:

{
    "msgtype": "markdown",
    "markdown": {
        "title": "首屏会话透出的展示内容",
        "image": "http://bpit-public.oss-cn-beijing.aliyuncs.com/note_1_1572593268.jpg",
        "text": "# 这是支持markdown的文本 \n## 标题2  \n* 列表1 \n![alt 啊](https://img.alicdn.com/tps/TB1XLjqNVXXXXc4XVXXXXXXXXXX-170-64.png)"
    },
     "image_size": {
         "image_url_xxxxx": {
                "h": 100,
                "w": 100
           }
     }
}
{
    "msgtype": "markdown",
    "markdown": {
        "title": "首屏会话透出的展示内容",
        "image": "http://bpit-public.oss-cn-beijing.aliyuncs.com/note_1_1572593268.jpg",
        "text": "# 这是支持markdown的文本 \n## 标题2  \n* 列表1 \n![alt 啊](https://img.alicdn.com/tps/TB1XLjqNVXXXXc4XVXXXXXXXXXX-170-64.png)"
    },
     "at": {
         "atMobiles": [
             "150********",
             "186********"
         ],
         "atWorkCodes": [
             "171765"
         ],
         "isAtAll": false
     }
}
参数 参数类型 必须 说明
msgtype String 消息类型,此时固定为:markdown【只有text、markdown类型的消息支持@】
title String 首屏会话透出的展示内容限制100个字符
text String markdown格式的消息,限制5000字符以内 (目前markdown格式客户端展示有问题,如果需要在markdown里添加图片的话可以先用image字段替换)
image String 图片 url,图片比例要求 宽:高 = 2:1
image_size String 指定图片的宽高

注意事项:可以给markdown消息正文中的图片配置跳转链接,配置跳转链接后将不再支持图片的放大预览,具体格式如下:

[![课程列表](https://static0.xesimg.com/studycenter/tool/apu/app_more_courselist.png)](https://www.baidu.com)

如果markdown中使用html标签,为了各端展示一致,请不要使用超出以下范围的标签


字体大小颜色(<span style="font-size:20px;color:#FF0000;">红色正常16号文本</span>)

粗体字体大小颜色(<b style="font-size:16px;color:#FF0000;">红色加粗16号文本</b><u>下划线</u>

<del>删除线</del>

<i>斜体</i>

对齐方式
<p align="right">这是右对齐</p>
<p align="center">这是居中对齐</p>
<p align="center">这是居中对齐,<span style="color:#FF0000;"><b><del><i>自定义颜色粗体+斜体+删除线</i></del></b></span></p>


# 3、action_card

注意事项:single_url 、single_pc_url、single_mobile_url、action_url、action_pc_url、action_mobile_url 为   yach://yach.zhiyinlou.com/session/webview?url=这里放上接入方的跳转地址,记得提前url_encode编码一下

示例:yach://yach.zhiyinlou.com/session/webview?url=https%3a%2f%2fwww.taobao.com 如果PC端想要通过侧边栏打开的话,需要在上面的url链接后面,加上【pc_slide=true】

示例:yach://yach.zhiyinlou.com/session/webview?url=https%3a%2f%2fwww.taobao.com&pc_slide=true

如果PC端想要通过侧边栏打开后在右上角展示从浏览器打开的按钮,需要在上面的url链接后面,加上【browser_url=xxxxx】其中xxx为要在浏览器打开的地址,xxx需要进行urlencode

效果如下图: 效果图

btn_type字段的说明:

1:默认值,表示跳转链接

2:按钮,会触发请求url对应的接口地址(该接口需要在知音楼的白名单内),接入方的接口需要返回Json字符串,示例:{"code":200, "msg":"success"}

3:按钮,会触发机器人消息转发接口,比如评价消息的示例:yach://yach.zhiyinlou.com/session/robot?extra=%7B%22click%22:1%7D&type=appraise&nonce=1

6:按钮,唤起第三方独立应用,仅支持单个按钮的卡片消息(也就是仅支持single_url, 不支持btn_json_list),single_url为业务方应用的scheme地址

整体跳转示例:

{
    "msgtype": "action_card",
    "action_card": {
        "title": "是透出到会话列表和通知的文案(整体跳转类型)",
        "markdown": "支持markdown格式的正文内容",
        "image": "http://bpit-public.oss-cn-beijing.aliyuncs.com/note_1_1572593268.jpg",
        "content_title": "内容体title",
        "single_title": "查看详情-侧边栏打开",
        "single_url": "yach://yach.zhiyinlou.com/session/webview?url=这里放上接入方的跳转地址,记得提前url_encode编码一下",
        "single_pc_url": "yach://yach.zhiyinlou.com/session/webview?url=这里放上接入方的跳转地址,记得提前url_encode编码一下",
        "single_mobile_url": "yach://yach.zhiyinlou.com/session/webview?url=这里放上接入方的跳转地址,记得提前url_encode编码一下",
        "icon_url": "http://pic51.nipic.com/file/20141027/19767535_164340333430_2.jpg",
        "btn_type": 1
    },
    "remind":{ // 提醒内容(目前仅支持action_card类型)
        "title":"XXX通知",
        "sub_title":"XXX通知",
        "content":"XXX的周报",
        "btn_type":1,
        "btn_url":"yach://yach.zhiyinlou.com/session/webview?url=这里放上接入方的跳转地址,记得提前url_encode编码一下"
    }
}

竖排按钮示例:

{
    "msgtype": "action_card",
    "action_card": {
        "title": "是透出到会话列表和通知的文案(竖排按钮)",
        "markdown": "支持markdown格式的正文内容",
        "image": "http://bpit-public.oss-cn-beijing.aliyuncs.com/note_1_1572593268.jpg",
        "content_title": "内容体title",
        "btn_orientation": "0",
        "btn_json_list": [
            {
                "title": "按钮名称-浏览器打开",
                "action_url": "yach://yach.zhiyinlou.com/session/webview?url=这里放上接入方的跳转地址,记得提前url_encode编码一下",
                "action_pc_url": "yach://yach.zhiyinlou.com/session/webview?url=这里放上接入方的跳转地址,记得提前url_encode编码一下",
                "action_mobile_url": "yach://yach.zhiyinlou.com/session/webview?url=这里放上接入方的跳转地址,记得提前url_encode编码一下",
                "icon_url": "http://pic51.nipic.com/file/20141027/19767535_164340333430_2.jpg",
                "btn_type": 1
            },
            {
                "title": "按钮名称-侧边栏打开",
                "action_url": "yach://yach.zhiyinlou.com/session/webview?url=这里放上接入方的跳转地址,记得提前url_encode编码一下",
                "icon_url": "http://pic51.nipic.com/file/20141027/19767535_164340333430_2.jpg",
                "btn_type": 1
            }
        ]
    },
    "remind":{ // 提醒内容(目前仅支持action_card类型)
        "title":"XXX通知",
        "sub_title":"XXX通知",
        "content":"XXX的周报",
        "btn_type":1,
        "btn_url":"yach://yach.zhiyinlou.com/session/webview?url=这里放上接入方的跳转地址,记得提前url_encode编码一下"
    }
}

横排按钮示例:

{
    "msgtype": "action_card",
    "action_card": {
        "title": "是透出到会话列表和通知的文案(横排按钮)",
        "markdown": "支持markdown格式的正文内容",
        "image": "http://bpit-public.oss-cn-beijing.aliyuncs.com/note_1_1572593268.jpg",
        "content_title": "内容体title",
        "btn_orientation": "1",
        "btn_json_list": [
            {
                "title": "按钮名称-浏览器打开",
                "action_url": "yach://yach.zhiyinlou.com/session/webview?url=这里放上接入方的跳转地址,记得提前url_encode编码一下",
                "action_pc_url": "yach://yach.zhiyinlou.com/session/webview?url=这里放上接入方的跳转地址,记得提前url_encode编码一下",
                "action_mobile_url": "yach://yach.zhiyinlou.com/session/webview?url=这里放上接入方的跳转地址,记得提前url_encode编码一下",
                "icon_url": "http://pic51.nipic.com/file/20141027/19767535_164340333430_2.jpg",
                "btn_type": 1
            },
            {
                "title": "按钮名称-侧边栏打开",
                "action_url": "yach://yach.zhiyinlou.com/session/webview?url=这里放上接入方的跳转地址,记得提前url_encode编码一下",
                "icon_url": "http://pic51.nipic.com/file/20141027/19767535_164340333430_2.jpg",
                "btn_type": 1
            }
        ]
    },
    "remind":{ // 提醒内容(目前仅支持action_card类型)
        "title":"XXX通知",
        "sub_title":"XXX通知",
        "content":"XXX的周报",
        "btn_type":1,
        "btn_url":"yach://yach.zhiyinlou.com/session/webview?url=这里放上接入方的跳转地址,记得提前url_encode编码一下"
    }
}
参数 参数类型 必须 说明
msgtype String 消息类型,此时固定为:action_card
title String 首屏会话透出的展示内容,限制100个字符
content_title String 内容体title
markdown String 内容体content,限制5000字符以内
btn_orientation String 使用独立跳转ActionCard样式时的按钮排列方式,竖直排列(0),横向排列(1);必须与btn_json_list同时设置
single_title String 使用整体跳转ActionCard样式时的标题,必须与single_url同时设置,最长20个字符
single_url String 消息点击链接地址
single_pc_url String PC端消息点击链接的跳转地址,想与移动端区分跳转地址时候,可传该参数
single_mobile_url String 移动端消息点击链接地址,想与PC端区分跳转地址时候,可传该参数
icon_url String 按钮图标地址
btn_type String 点击链接地址是否触发动作,默认不传
btn_json_list String 使用独立跳转ActionCard样式时的按钮列表。
image String 图片url
btn_json_list.title String 使用独立跳转ActionCard样式时的按钮的标题,最长20个字符。
btn_json_list.action_url String 消息点击链接地址(不需要拼接知音楼前缀和urlencode
)
btn_json_list.action_url String 消息点击链接地址
btn_json_list.action_pc_url String PC端点击链接地址,想与移动端区分跳转地址时候,可传该参数
btn_json_list.action_mobile_url String 移动端点击链接地址,想与PC端区分跳转地址时候,可传该参数
btn_json_list.icon_url String 按钮图标地址
btn_json_list.btn_type String 点击链接地址是否触发动作,默认不传
remind.title String 提醒相关配置-标题
remind.sub_title String 提醒相关配置-目前仅支持action_card类型-子标题
remind.content String 提醒相关配置-目前仅支持action_card类型-提醒内容
remind.btn_type String 提醒相关配置-目前仅支持action_card类型-触发动作类型(1:跳转链接)
remind.btn_url String 提醒相关配置-目前仅支持action_card类型-链接跳转地址,格式参考:single_url字段

# 4、图片消息:

{
    "msgtype": "image",
    "image": {
        "url": "https://yach-static.zhiyinlou.com/yach/avatar1/18b85ab1eddf66dd5be67d62489db637_s120.jpg"
    }
}
参数 参数类型 必须 说明
msgtype String 消息类型,此时固定为:image
url String 图片链接
width String 图片宽度
height String 图片高度
origin_url String 原图链接(如需点击查看原图则需要传该字段)
origin_width String 原图宽度
origin_height String 原图高度
file_name String 文件名称
file_size String 文件大小

# 5、链接消息:

{
    "msgtype": "link",
    "link": {
        "message_url": "",
        "pic_url": "https://yach-static.zhiyinlou.com/yach/avatar1/18b85ab1eddf66dd5be67d62489db637_s120.jpg",
        "title": "标题",
        "text": "描述"
    }
}
参数 参数类型 必须 说明
msgtype String 消息类型,此时固定为:link
message_url String 消息点击链接地址
pic_url String 图片地址
title String 消息标题,建议100字符以内
text String 消息描述,建议500字符以内

# 6、语音消息:

{
    "msgtype": "audio",
    "audio": {
        "url": "https://yach-static.zhiyinlou.com/test/jsapi/222068/1590142961532/15abdf5b0fba92ec100cdbd145465d94/ec8e9914-98ff-4e7d-b8d1-8a38af431e33.aac",
        "duration": 45,
        "size": 10086,
        "ext": "acc"
    }
}
参数 参数类型 必须 说明
msgtype String 消息类型,此时固定为:audio
url String 语音文件链接地址
duration Int 正整数,小于60,表示音频时长,单位秒
size Int 语音文件大小,单位KB
ext String 语音文件扩展名,示例:acc、amr

# 7、文件消息(仅支持私聊、群聊):

1、发送的文件地址必须是公网可访问的文件地址

2、备注说明:pdf文件需要传【https】的链接,否则IOS端无法预览

{
    "msgtype": "file",
    "file": {
        "name": "WiFi接入手册.docx",
	    "url": "https://yach-xstatic.zhiyinlou.com/online/person/1597298085840/bjw5ix56lmt/****.docx",
	    "size": 967013
    }
}
参数 参数类型 必须 说明
msgtype String 消息类型,此时固定为:file
name String 文件名称
url String 调用完腾讯cos之后拿到的文件链接
size String 文件大小,单位Kb,文件大小必须填写,否则下载没有进度条,文件大小和文件一致,否则下载的文件会出现损坏不能打开

# 8、视频消息(仅支持私聊、群聊):

1、发送该消息前,需要先调用获取腾讯云cos配置接口拿到腾讯云cos的临时密钥信息。

2、参考腾讯云对象存储SDK文档并下载对应的SDK,调用腾讯云的接口把业务方的图片、文件、视频上传到腾讯云。

3、拿到腾讯云接口返回的视频链接,再通过该消息类型发送到知音楼。

4、备注说明:不使用腾讯云对象存储进行视频上传的话,duration、size字段为必传参数,否则视频展示及播放可能会有未知问题。

{
    "msgtype": "video",
    "video": {
        "name": "视频发送于2020-07-13_14_42.mp4",
        "url": "https://yach-static.zhiyinlou.com/test/group/1594651255788/kjgicsmv0v/****.mp4"
    }
}
参数 参数类型 必须 说明
msgtype String 消息类型,此时固定为:video
name String 文件名称
url String 调用完腾讯cos之后拿到的视频链接
duration Int 正整数,表示视频时长,单位秒
size String 视频大小,单位Kb
width String 视频宽度
height String 视频高度

# 9、页面跳转消息(自动打开指定页面,url字段格式请参考:markdown消息的说明):

{
    "msgtype": "custom",
    "custom": {
        "type": "1",
        "body": {
            "url": "yach://yach.zhiyinlou.com/session/webview?url=encode编码后的链接"
        }
    }
}
参数 参数类型 必须 说明
msgtype String 消息类型,此时固定为:custom
type String 类型(1:跳转链接)
body.url String 需要跳转的链接地址,请参考示例进行url_encode编码处理

# 10、灰色Tips消息:

{
    "msgtype": "tips",
    "tips": {
        "text": "您已成功进行了评价 20:56"
    }
}
参数 参数类型 必须 说明
msgtype String 消息类型,此时固定为:tips
text String 提示文案

# 11、流式消息(仅聊天机器人支持):

{
  "msgtype":"stream",
  "stream":{
    "stream_id":"xxxxxxx1xxxx",
    "quote_msg_id":"112121212121"
  }
}
参数 参数类型 必须 说明
msgtype String 消息类型,此时固定为:stream
stream_id String 消息流ID,知音楼开放平台会携带query参数以get方式请求聊天机器人回调域名,请确保可以正常接收处理,响应数据按照下面格式响应,响应格式为 Content-Type:text/event-stream
quote_msg_id String 引用回复的消息ID,要引用回复指定消息的话将机器人抄送消息的quote_msg_id传递过来

响应数据流单个 event 格式如下:

{
  "msg_id":"xxxxxxx1xxxx",
  "content":"知",
  "is_finished": false
}

# 12、互动消息卡片

参数 参数类型 必须 说明
msgtype String 消息类型,此时固定为:sscard
last_msg String 会话列表消息展示内容 ,如果不传,会从sscard中的header组件和text组件中获取,如果没有此类组件,会显示默认文案
sscard List UI 组件列表,组件定义参考互动消息卡片组件
private_msg Object 用户私有数据,只有在群聊场景支持
└ message_list MapArray 用户私有的消息内容,message_list中的消息和sscard中的组件完全通用
└ user_data MapArray 用户私有的消息内容
{
    "msgtype": "sscard",
    "sscard": [{"id":"component_id_text","type":"text","content":{"type":"plain_text","i18n":{"zh_cn":"这是一个文案。","en_us":"This is a copy."}}}],
     "private_msg": {
     	"message_list":{
     		"agree":[{"id":"component_id_text","type":"text","content":{"type":"plain_text","i18n":{"zh_cn":"同意的文案。","en_us":"This is a agree."}}}]
     		"refuse":[{"id":"component_id_text","type":"text","content":{"type":"plain_text","i18n":{"zh_cn":"拒绝的文案。","en_us":"This is a agree."}}}]
     	},
     	"user_data":{
          //数组中的用户ID不能重复,多个数组中的也不能重复
     		"agree":["yach167680"]//yach167680这个用户看到的是private_msg.message_list.agree的内容
     		"refuse":["yach167680"]//yach167680这个用户看到的是private_msg.message_list.refuse的内容
     	}
     }
} 

# sscard仅支持的接口列表

1.发送助手消息

2.点对点普通消息

3.发送工作通知

4.点对点机器人消息

5.点对群消息

6.点对点机器人群消息

{
	"msgtype": "sscard",
    "last_msg": "这里是会话消息列表展示内容",
	"sscard": [{
		"type": "input",
		"id": "title",
		"title": {
			"i18n": {
				"zh_cn": "标题",
				"en_us": "title"
			}
		},
		"placeholder_title": {
			"i18n": {
				"zh_cn": "",
				"en_us": ""
			}
		},
		"length": 100,
		"action_url": "https://xxxxx/test/sscard",
		"extra": "",
		"required": true,
		"required_tips": {
			"i18n": {
				"zh_cn": "请输入标题",
				"en_us": "please input title"
			}
		},
		"prompt_tips": {
			"i18n": {
				"zh_cn": "",
				"en_us": ""
			}
		},
		"default_text": {
			"i18n": {
				"zh_cn": "新建日程",
				"en_us": "新建日程"
			}
		}
	}, {
		"type": "date_picker",
		"id": "start_time",
		"title": {
			"i18n": {
				"zh_cn": "开始时间",
				"en_us": "startTime"
			}
		},
		"placeholder_title": {
			"i18n": {
				"zh_cn": "",
				"en_us": ""
			}
		},
		"action_url": "https://xxxxx/test/sscard",
		"extra": "",
		"required": true,
		"required_tips": {
			"i18n": {
				"zh_cn": "请输入开始时间",
				"en_us": "please input start time"
			}
		},
		"prompt_tips": {
			"i18n": {
				"zh_cn": "",
				"en_us": ""
			}
		},
		"relation_tips": {
			"i18n": {
				"zh_cn": "开始时间必须早于结束时间",
				"en_us": "start time must after end time"
			}
		},
		"format": "yyyy-MM-dd HH:mm",
		"default_time": 1712654165
	}, {
		"type": "date_picker",
		"id": "end_time",
		"title": {
			"i18n": {
				"zh_cn": "截止时间",
				"en_us": "endTime"
			}
		},
		"placeholder_title": {
			"i18n": {
				"zh_cn": "",
				"en_us": ""
			}
		},
		"action_url": "https://xxxxx/test/sscard",
		"extra": "",
		"required": true,
		"required_tips": {
			"i18n": {
				"zh_cn": "请输入截止时间",
				"en_us": "please input end time"
			}
		},
		"prompt_tips": {
			"i18n": {
				"zh_cn": "",
				"en_us": ""
			}
		},
		"relation_type": "after",
		"relation_id": "start_time",
		"relation_tips": {
			"i18n": {
				"zh_cn": "结束时间必须晚于开始时间",
				"en_us": "end time must before start time"
			}
		},
		"format": "yyyy-MM-dd HH:mm",
		"default_time": 1712655365
	}, {
		"type": "select_person",
		"id": "select_person",
		"title": {
			"i18n": {
				"zh_cn": "参会人",
				"en_us": "attendee"
			}
		},
		"placeholder_title": {
			"i18n": {
				"zh_cn": "",
				"en_us": ""
			}
		},
		"action_url": "https://xxxxx/test/sscard",
		"extra": "",
		"limit": 50,
		"required": true,
		"required_tips": {
			"i18n": {
				"zh_cn": "请选择参会人",
				"en_us": "please select attendee"
			}
		},
		"prompt_tips": {
			"i18n": {
				"zh_cn": "",
				"en_us": ""
			}
		},
		"default_person": "Yach111965"
	}, {
		"id": "conflict_text",
		"type": "text",
		"placeholder_title": {
			"i18n": {
				"zh_cn": "",
				"en_us": ""
			}
		},
		"content": {
			"type": "plain_text",
			"i18n": {
				"zh_cn": "111111",
				"en_us": "2222"
			},
			"attributes_i18n": {
				"zh_cn": null,
				"en_us": null
			}
		}
	}, {
		"id": "confirm_button",
		"type": "button",
		"mutually_exclusive": 2,
		"update_msg": false,
		"content": [{
			"id": "content_button",
			"text": {
				"i18n": {
					"zh_cn": "确认并创建",
					"en_us": "confirm and create"
				}
			},
			"extra": "",
			"text_color": "FFFFFF",
			"border_color": "326FEF",
			"background_color": "326FEF",
			"icon_position": 0,
			"url": "https://xxxxxx/test/sscard",
			"action_type": "request",
			"retrieve_values": ["title", "start_time", "end_time", "address", "select_person", "remark", "checkbox"],
			"click_success": {
				"i18n": {
					"zh_cn": "",
					"en_us": ""
				}
			}
		}]
	}]
}
上次更新: 12/21/2024, 9:58:00 AM
foo