Blinker 后台数据分析
如何解析出后台服务器认证信息,供自己的设备连接。
测试程序 天气 增加了 Debug输出信息功能
1手机APP添加控件信息

2硬件烧录程序
#define BLINKER_PRINT Serial
#define BLINKER_MQTT
#define BLINKER_DEBUG_ALL
#include <Blinker.h> char auth[] = "9a02fc93f6cf";
char ssid[] = "dongdong";
char pswd[] = "ldd123456"; #define BUTTON_1 "btn-qc4" void setup()
{
Serial.begin(115200); pinMode(LED_BUILTIN, OUTPUT);
digitalWrite(LED_BUILTIN, LOW); Blinker.begin(auth, ssid, pswd);
Blinker.wInit(BUTTON_1, W_BUTTON);
} void loop()
{
Blinker.run(); if (Blinker.available()) {
BLINKER_LOG2("Blinker.readString(): ", Blinker.readString()); uint32_t BlinkerTime = millis(); Blinker.beginFormat();
Blinker.vibrate();
Blinker.print("millis", BlinkerTime);
Blinker.endFormat();
} if (Blinker.button(BUTTON_1)) {
digitalWrite(LED_BUILTIN, !digitalRead(LED_BUILTIN));
String get_weather = Blinker.weather(); BLINKER_LOG2("weather: ", get_weather); Blinker.delay(60000);
}
}
最重要在 #define BLINKER_DEBUG_ALL 可以打印出服务器返回数据,里面有认证账号和密码
3返回的消息
[50] Blinker v0.1.5
[50] Connecting to dongdong
[605] Connected
[605] Your IP is: 192.168.1.102
[605] authkey: 9a02fc93f6cf
[605] HTTPS begin: https://iotdev.clz.me/api/v1/user/device/diy/auth?authKey=9a02fc93f6cf
[1374] [HTTP] GET... code: 200
[1378] reply was:
[1378] ==============================
[1378] {"detail": {"broker": "aliyun", "deviceName": "67DEBCDA4YFZURWW9H5KOLTW", "iotId": "qAQieJeIJ64YqEM8Bze60010c40400", "iotToken": "27c0df1e500b43f39c7b750f6f09604e", "productKey": "JgCGbHlndgz", "uuid": "67c3698830d0482a6b96256526e01ecf"}, "message": 1000}
[1395] ==============================
[1400] ====================
[1401] DEVICE_NAME: 67DEBCDA4YFZURWW9H5KOLTW
[1405] MQTT_PRODUCTINFO: JgCGbHlndgz
[1408] MQTT_ID: 67DEBCDA4YFZURWW9H5KOLTW
[1412] MQTT_NAME: qAQieJeIJ64YqEM8Bze60010c40400
[1416] MQTT_KEY: 27c0df1e500b43f39c7b750f6f09604e
[1421] MQTT_BROKER: aliyun
[1423] HOST: public.iot-as-mqtt.cn-shanghai.aliyuncs.com
[1428] PORT: 1883
[1430] UUID: 67c3698830d0482a6b96256526e01ecf
[1434] ====================
[1437] BLINKER_PUB_TOPIC: /JgCGbHlndgz/67DEBCDA4YFZURWW9H5KOLTW/s
[1442] BLINKER_SUB_TOPIC: /JgCGbHlndgz/67DEBCDA4YFZURWW9H5KOLTW/r
[1451] mDNS responder started
[1452] webSocket server started
[1454] ws://67DEBCDA4YFZURWW9H5KOLTW.local:81
[1458] ESP8266_MQTT Initialled...
[2462] Current time: Fri Jul 27 03:59:57 2018 [6448] Connecting to MQTT...
只需要知道6个信息
服务器端口[1428] PORT: 1883
服务器域名 [1423] HOST: public.iot-as-mqtt.cn-shanghai.aliyuncs.com
分配用户账号[1412] MQTT_NAME: qAQieJeIJ64YqEM8Bze60010c40400
分配用户密码[1416] MQTT_KEY: 27c0df1e500b43f39c7b750f6f09604e
在服务器上的消息
[1437] BLINKER_PUB_TOPIC: /JgCGbHlndgz/67DEBCDA4YFZURWW9H5KOLTW/s
[1442] BLINKER_SUB_TOPIC: /JgCGbHlndgz/67DEBCDA4YFZURWW9H5KOLTW/r
测试
打开手机MQTT调试助手
设置信息 域名+端口+账号+密码

设置接受话题和发送话题

打开blinker app 每次在 blinker app上按下按钮(键值 btn-qc4)
就会接收到消息
刚开始成功了
过会就掉了,不知道为什么
(中间不小心重启了ESP8266)
牛逼 竟然是动态密码
1每次刷了官方的固件ESP8266重启发送HTTP请求,域名端口 账号不变 密码重新生成。
由于调试助手每次只连接MQTT服务器而不发起HTTP请求,所以不会修改密码,关闭打开仍然可用。
2 睡了一早上,打开手机调试助手怎么也连不上,重新用ESP发起请求一次获得新密码,看样子隔段时间密码还会变的,只能从服务器从新获取。
如下图 在新设备里自定义一个按键,两个滑块,一个开关,分别按下

收到的消息如下图,
JSON数据格式 {1设备类型 2数据 {控件键值(按键)+数据 3从哪来 4 到哪去 }(下面是话题名)

至此,全部搞明白
Blinker 的流程是这样的
0手机注册一个新设备,设备里面有很多操作控件(按键,滑块)。分配一个KEY
1 ESPP8266终端利用手机的设备分配的KEY,当唯一HTTP用户认证名,向HTTP服务发起请求,获取分配的服务器+端口+认证账户+动态认证密码+接收和发送消息话题,每次程序重启就会发起一次,每次就会修改一次认证密码,其余不变。
--
2 ESP8266终端获取到认证消息后,利用这些消息连接MQTT服务器,进行数据交互
每一个设备分配一个大话题,在此之下,每个控件(按键,滑块)在手机端设置的键值,就是区分消息源的关键。
蹭的很开心!
后续深入
认证使用的是阿里物联网套件
https://www.alibabacloud.com/help/zh/doc-detail/73742.htm

应该是第二种 使用HTTPS认证再连接模式
MQTT认证模式
http://emqtt.com/docs/v2/plugins.html
推测是HTTP解析认证
1ESP访问
HTTPS begin: https://iotdev.clz.me/api/v1/user/device/diy/auth?authKey=9a02fc93f6cf
得到回应
{"detail": {"broker": "aliyun", "deviceName": "67DEBCDA4YFZURWW9H5KOLTW", "iotId": "qAQieJeIJ64YqEM8Bze60010c40400", "iotToken": "27c0df1e500b43f39c7b750f6f09604e", "productKey": "JgCGbHlndgz", "

服务器网站和端口
[1423] HOST: public.iot-as-mqtt.cn-shanghai.aliyuncs.com
[1428] PORT: 1883
MQTT信息
[1401] DEVICE_NAME: 67DEBCDA4YFZURWW9H5KOLTW
[1405] MQTT_PRODUCTINFO: JgCGbHlndgz
[1408] MQTT_ID: 67DEBCDA4YFZURWW9H5KOLTW
[1412] MQTT_NAME: qAQieJeIJ64YqEM8Bze60010c40400
[1416] MQTT_KEY: 27c0df1e500b43f39c7b750f6f09604e
[1421] MQTT_BROKER: aliyun
[1423] HOST: public.iot-as-mqtt.cn-shanghai.aliyuncs.com
[1428] PORT: 1883
[1430] UUID: 67c3698830d0482a6b96256526e01ecf
发布和接受的话题
[1437] BLINKER_PUB_TOPIC: /JgCGbHlndgz/67DEBCDA4YFZURWW9H5KOLTW/s
[1442] BLINKER_SUB_TOPIC: /JgCGbHlndgz/67DEBCDA4YFZURWW9H5KOLTW/r
最后不断自己发粗心跳包

Blinker 后台数据分析的更多相关文章
- 初步了解SequoiaDB数据库
随着企业中日益复杂与多变的需求,以及迅速扩展带来的海量数据的业务,IT部门需要将越来越多的信息提供给用户,同时在现今的全球经济背景环境下,IT部 门还需要在提供高效服务的同时,降低其设备与程序维护成本 ...
- 第八次作业(课堂实战)- 项目UML设计(团队)
1. 团队信息 队名:小白吃队 成员: 后敬甲 031602409 卢泽明 031602328 蔡文斌 031602301 葛亮 031602617 刘浩 031602423 黄泽 031602317 ...
- 2018软工实践作业八之UML设计
1. 团队信息 队名:小白吃队 成员: 后敬甲 031602409 卢泽明 031602328 蔡文斌 031602301 葛亮 031602617 刘浩 031602423 黄泽 031602317 ...
- 深入学习sequoiadb巨杉数据库及python连接方式
随着公司日益复杂与多变的需求,以及迅速扩展带来的海量数据业务,我们需要在提供高效服务的同时,降低其设备与程序维护成本.算了,不吹了,说白了就是需要从巨杉数据库中抓取大量的数据,但是我现在不会,所以需要 ...
- Django ---- blog项目学习所得
一.登录功能 1.采用ajax 提交form表单的方式 2.后台生成随机验证码,登录时提交验证码 3.用PLI库生成随机验证码,置于session中,登录时与前台提交的code进行upeer()的验证 ...
- 利用NPOI导出数据到Execl
相信很多童鞋都开发过Execl的导入导出功能,最近产品中无论是后台数据分析的需要,还是前端满足用户管理的方便,都有Execl导入导出的维护需求产生. 以前做这个功能,如果是web,利用HttpCont ...
- 腾讯技术分享:Android版手机QQ的缓存监控与优化实践
本文内容整理自公众号腾讯Bugly,感谢原作者的分享. 1.问题背景 对于Android应用来说,内存向来是比较重要的性能指标.内存占用过高,会影响应用的流畅度,甚至引发OOM,非常影响用户体验.因此 ...
- 微信小程序---协同工作和发布
(1)协同开发和发布 在中大型的公司里,人员的分工非常仔细,一般会有不同岗位角色的员工同时参与同一个小程序项目.为此,小程序平台设计了不同的权限管理使得项目管理者可以更加高效管理整个团队的协同工作. ...
- V2X:
一篇文章读懂V2X系列:标准篇 为了提升交通系统的安全性和智能化,智能交通系统的概念正逐渐兴起.智能交通可以利用新一代的通信网络和数据处理能力,提高现有交通系统的整体效率,降低能量损耗,增加运输的安全 ...
随机推荐
- Spring JDBCTemplate连接SQL Server之初体验
前言 在没有任何框架的帮助下我们操作数据库都是用jdbc,耗时耗力,那么有了Spring,我们则不用重复造轮子了,先来试试Spring JDBC增删改查,其中关键就是构造JdbcTemplate类. ...
- webpack4 系列教程: 前言
1. 什么是webpack? 前端目前最主流的javascript打包工具,在它的帮助下,开发者可以轻松地实现加密代码.多平台兼容.而最重要的是,它为前端工程化提供了最好支持.vue.react等大型 ...
- HDU3567
Eight II Time Limit: 4000/2000 MS (Java/Others) Memory Limit: 130000/65536 K (Java/Others)Total S ...
- linux学习笔记-开机流程与主引导分区(MBR)
我的邮箱地址:zytrenren@163.com欢迎大家交流学习纠错! 读鸟哥的linux私房菜-基础学习篇(第三版)3.2.4章节作此笔记 一.术语介绍: Bios:写入到主板上的一个程序,计算机开 ...
- Python 类的祖宗--metaclass
1.Python 中一切事物都是对象 2.类都是 type 类的对象 类的两种申明方法 # 方法一: class Foo: def func(self): print(666) obj = Foo() ...
- Django&Flask区别
Flask Flask 本身只有一个内核,几乎所有的功能都需要用第三方的扩展来实现. Flask 没有默认使用的数据库,默认依赖两个外部库:Jinja2 模板引擎和 WSGI 工具箱(采用的时 Wer ...
- 正则与python的re模块
一.正则表达式的语法 正则表达式使用反斜杠字符('\')来表示特殊的形式或者来允许使用特殊的字符而不要启用它们特殊的含义.这与字符串字面值中相同目的的相同字符的用法冲突:例如,要匹配一个反斜线字面值, ...
- 【读书笔记】iOS-解析JSON
JSON相比XML最显著的优点是不需要使用重量级的解析库,因为其本身就是面向数据的,而且非常容易转换成哈希字典.除此之外,JSON文档相比同样的XML文档更小.在网络宽带有限的情况下,你很容易在Iph ...
- loadrunner 脚本开发-执行操作系统命令
脚本开发-执行操作系统命令 by:授客 QQ:1033553122 思路: 用loadrunner system()函数 函数原型: int system( const char *string ); ...
- Java数据解析---JSON
一.Java数据解析分为:XML解析和JSON解析 XML解析即是对XML文件中的数据解析,而JSON解析即对规定形式的数据解析,比XML解析更加方便 JSON解析基于两种结构: 1.键值对类型 { ...