-
本系列博客学习由非官方人员 半颗心脏 潜心所力所写,仅仅做个人技术交流分享,不做任何商业用途。如有不对之处,请留言,本人及时更改。
-
1、 php对接AliGenie天猫精灵服务器控制智能硬件esp8266① 在阿里云购买搭建私有云服务器,配置 SSL 证书 ,做好准备工作!
-
2、 php对接AliGenie天猫精灵服务器控制智能硬件esp8266② 全面认识第三方授权机制 oauth2.0 协议,如何在 php 上搭建 oauth2.0服务端!
-
3、 php对接AliGenie天猫精灵服务器控制智能硬件esp8266③渗入熟悉AliGenie 对接协议,揭开第三方云平台是如何让天猫精灵是发送消息到私有服务器的!
-
文章目录
- 一、前言;
- 二、天猫精灵如何授权?
- 三、天猫精灵请求有哪些?
- 3.1 发现设备列表:
- 3.2 查询某个设备属性:
- 3.3 控制某个设备:
- 四、天猫精灵请求我们应该如何响应?
- 4.1 发现设备列表响应:
- 4.2 查询某个设备状态回应:
- 4.3 控制某个设备回应:
- 五、其他
一、前言;
- 新年也快来临了,一个月没写嵌入式开发代码了。临近年末,工作也就不断加紧,偶尔做下自己的服务器!天猫精灵对接已经完毕,今天抽出点时间,终于可以写下这篇文章了。
- 毕竟自己出身嵌入式,又自学于网络编程,这对整个协议的流程了解容易上手!因为涉及到一些商业机密,不想被骂!我这里就不在多详细地做笔记,只做协议分析,和在开发过程中遇到的坑。如有需要技术讨论,请加群群里大牛一起讨论。
二、天猫精灵如何授权?
- 上篇文章已经提到,在开发时期,天猫精灵服务器官网会向我们在后台填写的地址发起一个
oauth2.0
协议的请求,要识别这个是否oauth2.0
的请求,需要自己来做判断。下面,我们来看看我的后台授权截图:、- 天猫精灵发起请求,之后,我们自己向用户展示一个登录界面 ,用来绑定此账号下面的所有设备。
- 服务器验证密码账号是否正确,之后天猫精灵会拿我们的授权码去兑换
access_token
,然后我们根据这个access_token
就可以识别是天猫精灵根据哪个用户来请求数据了。 - 下面的是
aligenie
服务器后台授权,当我们的应用被通过审核就可以在天猫精灵app上操作这个了!
三、天猫精灵请求有哪些?
- 开始这个的讲解,要知道天猫精灵服务器很人性化,把设备的某个属性作为技能点来写入和读取,这种编程思想让我很感觉到是
AI
时代的进步!那么,下面的协议都是涉及有技能点设计以及请求的动作! - 上面已经提到了如果授权成功,那么天猫精灵会来向我们的服务器发起请求,那么我们服务器需要怎么样来做判断这个请求了?其实在开发文档中非常详细了:点我查看
- 协议请求时候,都是
json
数据,以下面控制为例:
{"header":{"namespace":"AliGenie.Iot.Device.Control","name":"TurnOn","messageId":"1bd5d003-31b9-476f-ad03-71d471922820","payLoadVersion":1},"payload":{"accessToken":"123456789abc","deviceId":"34234","deviceType":"light","attribute":"powerstate","value":"on","extensions":{"extension1":"","extension2":""}}}
messageId
是作为调试追踪某个消息来的,总的来说,没什么用!- 其实我们看
header
里面的namespace
就可以知道天猫精灵请求都是什么内容了!总的来说就只有三个:
namespace | 含义 |
---|---|
AliGenie.Iot.Device.Discovery | 设备发现,天猫精灵来请求当前用户的设备列表 |
AliGenie.Iot.Device.Control | 设备控制,控制某个设备 |
AliGenie.Iot.Device.Query | 设备属性查询,查询某个设备的状态 |
3.1 发现设备列表:
- 以下面为例,简单分析天猫精灵在请求什么?
name
就是上面我们说的在设备发现,说明天猫精灵来请求当前用户的设备列表了。- 那么这个天猫精灵是指哪个用户呢?我们根据颁发的
accessToken
来做识别就好了!
{"header": {"messageId": "bf5a411b-e65f-486f-84ed-123456789902","name": "DiscoveryDevices","namespace": "AliGenie.Iot.Device.Discovery","payLoadVersion": 1},"payload": {"accessToken": "d4c3e4c57f7415dac5be"}
}
3.2 查询某个设备属性:
- 因为目前天猫精灵不支持多设备查询!以下面单个设备查询为例:
- 首先我们服务器来看看这个
accessToken
是否有效期内? - 那么我们怎么知道这时候天猫精灵要查询哪个设备呢?看
deviceId
这个字段,这个字段是我们在发现设备时候返回给它的,查询或者控制时候,都是根据这个字段来的!
- 首先我们服务器来看看这个
{"header": {"messageId": "68a1f301-bc43-4cec-86d6-123456","name": "Query","namespace": "AliGenie.Iot.Device.Query","payLoadVersion": 1},"payload": {"accessToken": "0a8bb37def2b45e3e3c5d9c8af","attribute": "","deviceId": "a226","deviceType": "light","value": ""}
}
3.3 控制某个设备:
- 以下面控制为例
- 下面大概意思是:**控制
deviceId
为abc28
的设备灯类型的色温为 2 **。 name
是指设置动作,attribute
是指其属性,value
就是指其具体的数值了!可以为字符型或者整型!大家可以慢慢琢磨!
{"header": {"messageId": "8c134775-7640-4073-a9ad-a513483622222","name": "SetColorTemperature","namespace": "AliGenie.Iot.Device.Control","payLoadVersion": 1},"payload": {"accessToken": "0a8bb37def2b45e3e3","attribute": "colorTemperature","deviceId": "abc28","deviceType": "light","value": "2"}
}
四、天猫精灵请求我们应该如何响应?
- 响应的格式那肯定要遵循天猫精灵的文档协议,要不然它会说
我好像遇到了阻碍,智能家居遇到了问题!
- 每次响应的
name
正常的话都是在后面加个Response"
; - 注意响应格式的头部必须要
application/json;
4.1 发现设备列表响应:
payload
是我们的设备列表,而里面是一个对象数组,下面为例是2个设备,每一个设备里面都要有下面的字段,具体的含义自己去看文档。每个字段都是有意义的!要严格遵循!- 还有要注意的是,其不能包含特殊字符,要不然在天猫精灵app会显示不了!
- 有个坑就是:
actions
字段官网说该设备支持的技能点,但是在控制时候,天猫精灵还是发生其他技能点的控制信息来,感觉这个返回什么天猫精灵都没用的!
{"header": {"namespace": "AliGenie.Iot.DeviceCenter.Discovery","name": "DiscoveryDevicesResponse","messageId": "bf5a411b-e65f-486f-84ed-52891222222222222","payLoadVersion": 1},"payload": {"devices": [{"deviceId": "28","deviceName": "\u53cc\u8272\u706fB4E6","deviceType": "light","zone": "","brand": "","model": "\u534a\u9897\u5fc3\u810f\u54c1\u724c","icon": "https:\/\/www.domain.cn\/files\/ali_light.jpg","properties": [{"name": "powerstate","value": "off"}],"actions": ["TurnOn", "TurnOff", "SetBrightness", "AdjustBrightness", "SetTemperature", "Query"],"extensions": {"extension1": "","extension2": ""}}, {"deviceId": "26","deviceName": "cwLight68C6","deviceType": "light","zone": "","brand": "","model": "\u534a\u9897\u5fc3\u810f\u54c1\u724c","icon": "https:\/\/www.domain.com\/files\/ali_light.jpg","properties": [{"name": "powerstate","value": "off"}],"actions": ["TurnOn", "TurnOff", "SetBrightness", "AdjustBrightness", "SetTemperature", "Query"],"extensions": {"extension1": "","extension2": ""}}]}
}
4.2 查询某个设备状态回应:
- 下面可以看到,多了
properties
这个字段,而且里面都是一个数组,都是以键值对存在的! - 当你对天猫精灵说
客厅灯打开了吗?
,就会查询客厅灯设备状态。如果返回下面,就会说:客厅灯当前为打开状态,色温为2700,亮度为65。天猫精灵会不断地把properties
里面的属性一个一个读出来!@_@
{"properties": [{"name": "powerstate","value": "on"}, {"name": "onlinestate","value": "online"}, {"name": "remotestatus","value": "on"}, {"name": "colorTemperature","value": 2700}, {"name": "brightness","value": 65}],"header": {"namespace": "AliGenie.Iot.Device.Query","name": "QueryResponse","messageId": "0e2d981a-081b-44b6-9aa7-123456789","payLoadVersion": 1},"payload": {"deviceId": "abc28"}
}
4.3 控制某个设备回应:
- 这个回应就比较简单了:
name
数值为TurnOnResponse
,然后在payload
后面加上这个设备的deviceId
就可以了!
{"header":{"namespace":"AliGenie.Iot.Device.Control","name":"TurnOnResponse","messageId":"1bd5d003-31b9-476f-ad03-71d471922820","payLoadVersion":1},"payload":{"deviceId":"34234"}}
五、其他
- 后台配置详情:
- 之后,我们就可以在天猫精灵APP看到我们的设备了,品牌是
半颗心脏
,呵呵!