以下是一次典型请求中,sdk(客户端)收到的完整json数据
{
"status":0, //0 表示成功,其他值表示失败
"msg":"ok", //错误状态文本
"se_query":"我要听周杰伦的歌", //用户请求的query
"logid":"xxxx1234354", //日志查询用的logid
"id":"id12334235", //消息id
"user_id":"", //请求的用户id
"cuid":"", //请求的设备id
"time":1482226019, //当前的服务端时间戳
"client_msg_id": "string", //客户端上报的请求msg id,如果是回复用户的某个请求的消息,可以用这个字段串起来
"speech_id": "string", //如果是个语音请求,这是语音的id(请求中的speech_id字段,2合一的get参数sn)
"need_passport_login": false, //如果为true,客户端应该调用百度passport登录接口
"result":{
"bot_id":"duer_music", //返回结果的bot的id,如果没有任何垂类服务返回,bot_id== NO_RESULT
"bot_meta":{ //下游bot元数据
"description":"返回音乐类结果", // 文字描述
"version":"1.0.0", //版本
"type":"音乐" //TODO,bot类型见pm给的分类
},
"views":[ //显示用的数据,一个结果里可包含多个卡片
{
"type":"list", //卡片类型,只有txt,list,image三种类型
"list":[
{
"title": "东方破",
"image": "http://nodeapi.cloudfoundry.com/qrcode.jpg",
"url": "http://nodeapi.cloudfoundry.com/"
},
{
"title": "双截棍",
"image": "http://nodeapi.cloudfoundry.com/qrcode.jpg",
"url": "http://nodeapi.cloudfoundry.com/"
}
]
}
],
"directives":[ //指令,用于控制给客户端、目标硬件下达命令,可选字段,一个结果可包含多条啊指令
{
"header": { //指令的名字
"namespace": "AudioPlayer",
"name": "Play"
},
"payload": { //指令的参数
"play_behavior": "REPLACE_ALL",
"audio_item": {
"audio_item_id": "156",
"stream": {
"url": "http://yinyueshiting.baidu.com/data2/music/124088643/124088643.mp3?xcode=57462f29cfc176f86a37d80a2c02fc5b",
"stream_format": "AUDIO_MP3",
"offset_ms": 0,
"token": "156",
"progress_report_interval_ms": 10000
}
}
}
}
],
"nlu": { //query解析的结果
"domain": "music",
"intent": "music", //domain + intent确定一种解析结果的类型
"slots": { //从query中提取出来的槽位信息
"action_type":"1",
"singer": "周杰伦"
}
},
"resource":{ //数据资源,可选字段
"type":"music_ref",//资源类型,目前已经有music/news/weather等资源类型
"data":{
"api": {
"method": "GET",
"url": "http: //s.xiaodu.baidu.com/v20161223/resource/music?user_id=888"
}
//以上地址,可以增加page参数来翻页,如 http://s.xiaodu.baidu.com/v20161223/resource/music?user_id=888&page=2
//抓取以上api地址后会返回如下格式
/*
{
"status": 0,
"code": null,
"data": {
"page": 1,
"total_page": 5,
"list": [
{
"duration": "238",
"name": "恋红尘",
"alias": "",
"singer_name": "祁隆,彭丽嘉",
"all_singer_name": "",
"genre": "流行",
"tag": "好听,新歌,网络歌曲",
"language": "",
"original_singer": "",
"composer": "",
"lyricist": "",
"url": "http://music.baidu.com/song/271665582?fm=altg_new3",
"same_name_url": "http://music.baidu.com/search?fm=altg_new3&key=%E6%81%8B%E7%BA%A2%E5%B0%98",
"streaming_vedio_url": "http://zhangmenshiting.baidu.com/data2/music/a1d4eca5675d21e6e0b3dad002de5c1d/271665733/271665733.mp3?x
code=2e387ebc099d9e5aa0d51cfc739c1004",
"head_image_url": "http://qukufile2.qianqian.com/data2/pic/25b1faff5bf89f84b6491593e31381ed/271665166/271665166.jpg",
"album_name": "恋红尘",
"album_url": "",
"score": "0",
"publish_time": "2016-09-20",
"publish_company": "华宇世博",
"is_need_pay_listen": "0",
"from_site": "1",
"hot": "237391"
}...
]
}
}
*/
}
},
'should_end_session':false, //默认为true,如果为false,客户端应该立即进入收听用户query的状态,不用重新唤醒
"speech": { //TTS播报用的数据
"type": "Text", //有SSML和Text两种类型
"content": "为您播放周杰伦的歌曲",
"reprompt": "" //可选,should_end_session==false的时候,会自动进入语音识别状态,8s后如果用户都不说话,客户端会用tts播放一个短提示,reprompt就是短提示的内容
}
}
}
返回值 | 含义 |
---|---|
status:1,msg: appid unvalid | appid无效 |
status:2,msg: appkey unvalid | appkey无效 |
status:3,msg: appqps warning | appqps前一天峰值警告 |
status:4,msg: appqps refuse | appqps拒绝 |
status:5,msg: appqpd warning | appqpd前一天峰值警告 |
status:6,msg: appqpd refuse | appqpd拒绝 |
status:7,msg: sericelist empty | 请求的服务列表未配置 |
bot 是真正负责返回结果的度秘平台子服务,每条结果中会带有真正服务的bot的id和meta信息 下面的表格是现有的bot及其说明
bot_id | 说明 |
---|---|
phone | 电话服务 |
remind | 提醒服务 |
recommend_service_wireless source_sub_type: joke | 笑话 |
duer_weather | 天气服务 |
music | 音乐服务 |
restaurant_bot | 美食服务 |
life_common | 生活服务(地图导航) |
sac | 火车航班,查限行 |
aries_general aries_guide aries_dqa kg_service | 通用信息(翻译) |
sysprofile_service | 系统画像 |
image_satisfy | 图搜服务 |
返回展示卡片数据,必选字段。一次可返回一个或多个卡片。 一共有三种类型:
只能返回一段文本
{
"type":"txt",
"content":"为你推荐如下热门资讯",
"url":"http://www.baidu.com" //可选字段
}
{
"type":"list",
"list":[
{
"title": "你来我家接我吧",
"summary": "这是女神与高富帅之间的对话", ///可选字段
"image": "http://nodeapi.cloudfoundry.com/qrcode.jpg",//可选字段
"url": "http://nodeapi.cloudfoundry.com/"
},
{
"title": "你来我家接我吧",
"summary": "这是女神与高富帅之间的对话", //可选字段
"image": "http://nodeapi.cloudfoundry.com/qrcode.jpg",//可选字段
"url": "http://nodeapi.cloudfoundry.com/"
}
]
}
可一次返回多张图片,可选缩略图
{
"type": "image",
"list": [
{
"src":"http://c.hiphotos.baidu.com/image/pic/item/7af40ad162d9f2d38d7056c8acec8a136327ccb0.jpg",
"thumb":"http://c.hiphotos.baidu.com/image/pic/item/7af40ad162d9f2d38d7056c8acec8a136327ccb0.jpg" //可选字段 缩略图
},
{
"src":"http://b.hiphotos.baidu.com/image/pic/item/b21bb051f8198618df86c5424eed2e738ad4e637.jpg",
"thumb":"http://c.hiphotos.baidu.com/image/pic/item/7af40ad162d9f2d38d7056c8acec8a136327ccb0.jpg" //可选字段 缩略图
},
{
"src":"http://c.hiphotos.baidu.com/image/pic/item/83025aafa40f4bfbc9c817b9074f78f0f63618c6.jpg",
"thumb":"http://c.hiphotos.baidu.com/image/pic/item/7af40ad162d9f2d38d7056c8acec8a136327ccb0.jpg" //可选字段 缩略图
}
]
}
根据用户的意图和度秘服务的能力,在一些请求里会返回复杂的结构化数据,用于客户端的特殊逻辑和展示,现有的resource类型有以下几类,还在不断增加中
"resource":{
"type":"weather",
"data":{
"city": "北京",
"current_temp": "-1℃", //实时温度,只有query查询今天的天气的时候才会有值,如“今天天气怎么样”
"pm25": "426", //实时pm2.5,只有query查询今天的天气的时候才会有值,如“今天天气怎么样”
"temp": "-3℃~5℃", //当天的温度
"time": "周二 12月20日", //查询目标时间的文字描述
"weather": "雾",//天气的文字描述
"weather_all": "雾,-3℃~5℃,微风", //完整的天气描述
"wind": "微风",
"weather_info": [//未来5天的天气数据
{
"current_temp": "-1℃",
"icon": "http://s1.bdstatic.com/r/www/aladdin/img/new_weath/bigicon/4.png",
"pm25": "426",
"pm_level": "严重污染",
"temp": "-3℃~5℃",
"time": "周二 12月20日",
"weather": "雾",
"wind": "微风"
},
{
"icon": "http://s1.bdstatic.com/r/www/aladdin/img/new_weath/icon/7.png",
"temp": "-3℃~3℃",
"time": "周三 12月21日",
"weather": "霾",
"wind": "微风"
},
{
"icon": "http://s1.bdstatic.com/r/www/aladdin/img/new_weath/icon/1.png",
"temp": "-5℃~6℃",
"time": "周四 12月22日",
"weather": "晴",
"wind": "北风3-4级"
},
{
"icon": "http://s1.bdstatic.com/r/www/aladdin/img/new_weath/icon/1.png",
"temp": "-6℃~3℃",
"time": "周五 12月23日",
"weather": "晴转多云",
"wind": "北风微风"
},
{
"icon": "http://s1.bdstatic.com/r/www/aladdin/img/new_weath/icon/5.png",
"temp": "-5℃~3℃",
"time": "周六 12月24日",
"weather": "多云转霾",
"wind": "北风微风"
}
]
}
},
一次查询会返回多条新闻,现在是10条,新闻内容(content字段)如果太长会被截断
"resource":{
"type":"news",
"data":{
"list":[
{
"id":"xxx1234bbb",
"title":"河北首次启动区域红色应急响应 雾霾笼罩",
"summary":"河北首次启动区域红色应急响应 雾霾笼罩",
"content":"霾是什么?雾是什么?都是怎么形成的?它们的关系是什么?气温丶湿度丶风力丶风向丶地形丶地表丶温湿度丶灰尘丶烟尘丶粉尘丶扬尘那个危害更大,这些都应当弄清了,再谈霾和雾,不要把霾字前加雾字。这本来就是两种截然不同的两种物质。只是它们互相影响而已。把它们混为一谈。就是错的引导。霾在四五年前就已经开始了。只是越来越严重而已。它是随着汽车进入家庭而伴生的。", //新闻内容
"url":"http://headline.baidu.com/doc/detail?app_from=dumi_news&url_key=http%3A//news.163.com/photoview/00AP0001/2216510.html",
"image" : "http://ztd00.photos.bdimg.com/ztd/whfpf%3D160%2C120%2C50%3Bq%3D70/sign=1a96a9f0f41f4134e062563e4322a4fc/d000baa1cd11728bfb98b831c1fcc3cec3fd2c6f.jpg",
"thumb":"http://ztd00.photos.bdimg.com/ztd/whfpf%3D160%2C120%2C50%3Bq%3D70/sign=1a96a9f0f41f4134e062563e4322a4fc/d000baa1cd11728bfb98b831c1fcc3cec3fd2c6f.jpg",
"pubtime":"2016-12-20 20:01:01"
},
{
"id":"xxx1234bbb",
"title":"河北首次启动区域红色应急响应 雾霾笼罩",
"summary":"河北首次启动区域红色应急响应 雾霾笼罩",
"content":"霾是什么?雾是什么?都是怎么形成的?它们的关系是什么?气温丶湿度丶风力丶风向丶地形丶地表丶温湿度丶灰尘丶烟尘丶粉尘丶扬尘那个危害更大,这些都应当弄清了,再谈霾和雾,不要把霾字前加雾字。这本来就是两种截然不同的两种物质。只是它们互相影响而已。把它们混为一谈。就是错的引导。霾在四五年前就已经开始了。只是越来越严重而已。它是随着汽车进入家庭而伴生的。",
"url":"http://headline.baidu.com/doc/detail?app_from=dumi_news&url_key=http%3A//news.163.com/photoview/00AP0001/2216510.html",
"image":"http://ztd00.photos.bdimg.com/ztd/whfpf%3D160%2C120%2C50%3Bq%3D70/sign=1a96a9f0f41f4134e062563e4322a4fc/d000baa1cd11728bfb98b831c1fcc3cec3fd2c6f.jpg",
"thumb":"http://ztd00.photos.bdimg.com/ztd/whfpf%3D160%2C120%2C50%3Bq%3D70/sign=1a96a9f0f41f4134e062563e4322a4fc/d000baa1cd11728bfb98b831c1fcc3cec3fd2c6f.jpg",
"pubtime":"2016-12-20 20:01:01"
}
]
}
},
目前仅返回Text类型,SSML类型在开发中,SSML的说明
"speech": {
"type": "Text",
"content": "为您播放周杰伦的歌曲"
}
基础结构:
"directives":[ //指令,用于控制给客户端、目标硬件下达命令,可选字段,一个结果可包含多条啊指令
{
"header": {
"namespace": "",//指令的分类
"name": "" //指令的名字
},
"payload":{ //指令的参数
}
}
]
现在有以下namespace指令可能返回
- AudioPlayer 音乐播放相关指令
- Speaker 扬声器控制、设置相关指令
- SpeechSynthesizer 语音播报(TTS)相关指令
- 只有部分客户端支持的指令
- SpeechRecognizer 语音识别相关指令
- 只有部分客户端支持的指令
- Extension 部分客户端会收到的扩展指令
用户接下去可能会输入的query,可以用来给用户提示,辅助用户输入 比如下面的例子是“讲个笑话”这个query返回的hint
"hint":["再来一个", "文字笑话", "图片笑话"],
"nlu": { //query解析的结果
"domain": "music",
"intent": "music", //domain + intent确定一种解析结果的类型
"slots": { //从query中提取出来的槽位信息
"action_type":"1",
"singer": "周杰伦"
}
}
描述 | domain | intent | slots(可用的槽位) | example |
---|---|---|---|---|
火车票 | 22 | 22 | end_point(终点站), start_point(起点站), search_type(如:高铁), start_time(时间) | 给我买张到武汉的高铁票 |
天气 | duer_weather | sys_weather | loc_city(城市), loc_county(国家), loc_province(省), time(时间) | 北京明天天气如何 |
地址查询类需求 | lbs | poi | poi(地址字符串) | 射阳在哪儿 |
周边查询类需求 | lbs | nearby | start_point(出发地),start_point_bd_la(出发地纬度),start_point_bd_lo(出发地经度),user_location_city(用户当前所在城市),end_point(目的地),travel_type(出行方式),坐标类型为bd09ll(百度经纬度坐标) | 附近的飞机场 |
导航查询类需求 | lbs | navigation/route/traffic_condition | start_point(出发地),start_point_bd_la(出发地纬度),start_point_bd_lo(出发地经度),user_location_city(用户当前所在城市),end_point(目的地),travel_type(出行方式),坐标类型为bd09ll(百度经纬度坐标) | 导航从北京到上海 |
音乐类需求 | music | music | action_type(0. 关闭 1. 打开 2. 播放 3. 暂停 4. 下一首 5. 上一首 6. 换一首 7. 重播), song(歌名), singer(歌手), music_language(语言), music_emotion(情感,如悲伤、欢快等), music_tag, music_type(嘻哈、摇滚、儿歌等) | |
让度秘唱歌,类似调戏 | music | music_sing | CommandAccepter, action_type(0. 关闭 1. 打开 2. 播放 3. 暂停 4. 下一首 5. 上一首 6. 换一首 7. 重播), song(歌名), singer(歌手) | |
联系人查询需求 | phone | contact | action_type(1:查看 0:新建 2:发送), pinyin_for_view(要查看的联系人的拼音), name_for_view(要查看的联系人的名字), pinyin_to_send(要发送的联系人的拼音), name_to_send(要发送的联系人的名字) | 告诉我张凤仪的电话号码, 庞翔宇的电话号码发给张凤仪 |
打开网址 | phone | open_website | action_type, name, website_url | 携程火车票 |
发短信 | phone | sms | content(短信内容), number(目标号码), name(目标姓名), pinyin(目标姓名拼音) | 短信发给15140559455 |
提醒、闹钟 | remind | remind | action, event_title, intent, remind_time, remind_type_message, remind_type_phone, remind_type_dumi, remind_type_clock, remind_time_type, remind_time_value, remind_time_data, status | 设置提醒每天晚上9点半洗衣服。 |
美食、团购 | restaurant_bot | find | catetag, fragment, location, sortby, cuisine, crowd, groupon | 附近有什么好吃的饭馆 |