逆向狄X楼宇对讲机的485控制协议

成果:

点击对讲机屏幕智能家居灯光模块,对应灯打开或关闭。

起因:

笔者发现房屋自带的楼宇对讲机里有智能家居模块,想要将这块屏幕接入使用它控制灯光设备。

 

目标:

使用该设备的屏幕操作控制灯光,后面再控制空调,灯光,场景。

调查:

1、 厂商官网产品资料,发现楼宇对讲机,网络结构,设备网络接入的是楼宇间网络,楼下的对讲机。设备还有一个485接口,用于扩展智能家居控制。

逆向狄X楼宇对讲机的485控制协议_第1张图片

 逆向狄X楼宇对讲机的485控制协议_第2张图片

楼宇对讲接口图

2、 关键点485接入智能家居控制,什么是485?厂商有没有协议文档公开?查看厂商设备485怎么接入,设备价格?

调查后:

485是有线接入的智能控制方案,百度是总线,主/从设备模式。厂家的相关的模块也叫做有线智能网关,笔者的灯全是wifi的,也没有智能开关,这有线的485怎么接入控制WIFI设备?搞不了?

想法:

逻辑上485有线也是要传控制指令,设备收到指令后执行,执行动作。所以去抓下屏幕操作时对应485上的控制数据,然后转译成wi-fi灯的控制指令应该可以。

实现路径:

1、 分析485控制指令。
2、 485控制指令转译成控制wi-fi灯的控制指令(485传MQTT,HA用MQTT自动化)。

分析485控制指令

笔者开始是想自己写代码ESP32读485数据,因为是想要接入home assistant系统来控制,home assistant后面简称HA。ESP32可以走ESPHOME,集成到HA。
后面发现HF家的485透传模块,(提供透传到MQTT),还可以分包,这东西就是串口的wireshark,花了43块买了一个(关键模块特别小,6厘米长,笔者可以直接塞到对讲机后面的86底盒里)。

逆向狄X楼宇对讲机的485控制协议_第3张图片

逆向狄X楼宇对讲机的485控制协议_第4张图片 

协议似乎不是标准modbus,所以还是得分析,直接数据透传。

在屏幕上点击智能家居灯光控制。发现485上有数据,使用产品配套的TCP&UDP测试工具查看如下(已配置TCP sever路由485):逆向狄X楼宇对讲机的485控制协议_第5张图片

 

在屏幕上点亮第2盏灯,观察数据,对数据进行分组排列(因为串口有开始位和结束位)
什么都不点时RX:
ae d0 06 81 01 06
ae d0 08 82 01 00 00 09
ae d0 08 82 01 00 01 0a
ae d0 08 82 01 00 02 0b
ae d0 08 82 01 00 03 0c
ae d0 08 82 01 00 04 0d
ae d0 08 82 01 00 05 0e
ae d0 08 82 01 00 06 0f
ae d0 08 82 01 00 07 10
ae d0 08 83 01 00 00 0a
ae d0 08 83 01 00 01 0b

点亮第2盏灯时RX:
ae d0 06 81 01 06
ae d0 08 82 01 00 00 09
ae d0 08 82 01 00 01 0a
ae d0 08 82 01 00 02 0b
ae d0 08 82 01 00 03 0c
ae d0 08 82 01 00 04 0d
ae d0 08 82 01 00 05 0e
ae d0 08 82 01 00 06 0f
ae d0 09 02 01 00 01 01 8c
ae d0 08 82 01 00 07 10
ae d0 08 83 01 00 00 0a
ae d0 08 83 01 00 01 0b
测试其它项。

猜测灯状态改变包数据结构:
【帧头】【帧长度包括长度】【功能码】【地址码】【状态码】【可能是什么内容校验码】
AE D0 09 02 01 00 01 01 8C

状态码:00为关灯,01为开灯。
(串口是开始位和结束位,实际应该是D0开头,AE结束?不过不影响翻译控制了。笔者的关于串口的知识都是来自搜索引擎)

485控制指令转译成控制wi-fi灯的控制指令

配置透传MQTT,路由485:逆向狄X楼宇对讲机的485控制协议_第6张图片

 在HA中查看MQTT:逆向狄X楼宇对讲机的485控制协议_第7张图片

 经过上面的分析,可以设置为开头D0,结尾AE,组成帧,这样每一帧就会是一条MQTT消息。以便直接提取控制指令。逆向狄X楼宇对讲机的485控制协议_第8张图片在HA中查看MQTT就会是多条消息:逆向狄X楼宇对讲机的485控制协议_第9张图片

逆向狄X楼宇对讲机的485控制协议_第10张图片 

遗留问题

在多点控制时,没找到怎么去更新控制屏幕灯状态的发包,这样屏幕上显示的灯的状态可能和实际灯的状态不一致。推测什么都不做发的功能码8201是查询灯状态的包,但是搞不出来有效的回应包。或者这个玩意儿,就是这样子的,先天只能单点控制。

硬件
厂家 产品
狄X 楼宇对讲机AB-280M-S6001
HF 串口服务器
淘宝 杜绑线
淘宝 面包板
淘宝 RJ45网线
淘宝 12V电源,3.3V\5V供电模块(焊接出12V)

软件
TCP&UDP测试工具(HF),IOTsevice(HF),Home assistant,MQTT。

 

 

你可能感兴趣的:(软件开发,开源协议)