broadlink的智能插座sp2简单分析--更新

2023-11-03 23:59

本文主要是介绍broadlink的智能插座sp2简单分析--更新,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

转载请保留作者信息:星辉斑斓http://blog.csdn.net/hnmsky

最近入手一个broadlink的智能插座sp2.图就不上了,官网上有.拿到手第一印象觉得有些大,插在插排

上要占好几个位置.功能上wifi配置可以用smart config和ap模式,还是不错的.而且有功率统计,估计

里面有测量电流电压的芯片.

至于手机上的app,目前不是很完善.首先,这个app极其耗电,即使在后台也是.而且这个app有时会

卡住,然后从此再也搜索不到设备,要清除数据才可以,当时我以为坏了差点去退货.所以我准备自己写

程序来控制开关,这个也可以自己订制各种应用场景,毕竟等这个app完善还有段时间.

 

简单研究了下sp2, 有兴趣的可以再深入下.

配置wifi部分我觉得没有必要hack了, 感兴趣的可以参考[1],毕竟配置一次就可以了.


至于指令,无非就是开和关,这个用wireshark抓包就可以看出来.


指令是每次配置完都会变化,所以配置后就要重新抓包更改。所以抓的包只能自己用。

下面我说一下如何抓包:

  最好用PC通过网线来连接路由器,这样抓的包不是加密的。

1:在路由器上查看sp2的ip, 假设为192.168.0.102

2:如果你的电脑的网卡支持monitor模式,可直接看第4条。如果不支持moniter模式,现在自己电脑上的80端口运行个udp的echo server,就是把所有80端口收到的udp包都原封不动的发送回原来的发送端。我写了程序(server.c)可以参考。

3:把自己电脑ip改为和sp2一样,假设为192.168.0.102。

4:用wireshark抓包,可以看到开关指令其实就是2个udp包(开一个,关一个),其中data长度是72byte。大概类似于这个样子(0x5a,0xa5,0xaa,0x55,0x5a,0xa5,0xaa,0x55,0x00,0x00,0x00,0x00,0x00,0x00......)


这个是发送开指令时抓的包,其中192.168.0.101是nexus7 的ip, 192.168.0.102是开关的ip. 

可以看到手机发送一个udp包,然后sp2收到后会把这个把发送给手机.

5:要写这个程序就很简单了,把这个包(72byte)发出去,然后再收到包就成功了. 用python写了个示例代码,见sample.py。

因此要你自己抓包,然后用抓到数据,类似于这种(0x5a,0xa5,0xaa,0x55,0x5a,0xa5,0xaa,0x55,0x00,0x00,0x00,0x00,0x00,0x00......),替换掉程序里的on 和 off两个数组。




关于功率,可以看到sp2一直在给手机发包,功率信息应该在这里.不过这个就不研究了.


不知道像定时休眠一类的功能是用手机发命令还是外部服务器来发,但我没有发现sp2会经常

的连接外部服务器.(开始时会连一次的,应为需要NAT,这个可以参考[2])



代码在

http://download.csdn.net/detail/hnmsky/7434419 去掉了积分要求。

server.c 是echo server

sample.py 示例代码

我以前放的代码别人不能用的,所以要用这个新的,并自己抓包。现在sdk不开放给个人,所以就用这个方法凑合着用了,只能控制开关,不能看功率。

一些问题的更新:

1:抓包后,不能重新配置sp2去连接路由器,也不要去改路由器的配置(改密码啥的),这肯定是不行的。另外抓包不要通过wifi去抓加密的数据,通过eth口去抓解密好的数据。

2:抓的包要是点了手机App上开关按钮后,手机发出来的udp包,你点一次按钮,只会发3个udp的包。  不要去抓那个每过一段时间就会发的包,那个是用来查询状态的。


参考文献:

1:smartconfig

http://depletionregion.blogspot.ch/2013/10/cc3000-smart-config-transmitting-ssid.html

2:NAT

http://en.wikipedia.org/wiki/Network_address_translation


这篇关于broadlink的智能插座sp2简单分析--更新的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/341793

相关文章

性能分析之MySQL索引实战案例

文章目录 一、前言二、准备三、MySQL索引优化四、MySQL 索引知识回顾五、总结 一、前言 在上一讲性能工具之 JProfiler 简单登录案例分析实战中已经发现SQL没有建立索引问题,本文将一起从代码层去分析为什么没有建立索引? 开源ERP项目地址:https://gitee.com/jishenghua/JSH_ERP 二、准备 打开IDEA找到登录请求资源路径位置

csu 1446 Problem J Modified LCS (扩展欧几里得算法的简单应用)

这是一道扩展欧几里得算法的简单应用题,这题是在湖南多校训练赛中队友ac的一道题,在比赛之后请教了队友,然后自己把它a掉 这也是自己独自做扩展欧几里得算法的题目 题意:把题意转变下就变成了:求d1*x - d2*y = f2 - f1的解,很明显用exgcd来解 下面介绍一下exgcd的一些知识点:求ax + by = c的解 一、首先求ax + by = gcd(a,b)的解 这个

hdu2289(简单二分)

虽说是简单二分,但是我还是wa死了  题意:已知圆台的体积,求高度 首先要知道圆台体积怎么求:设上下底的半径分别为r1,r2,高为h,V = PI*(r1*r1+r1*r2+r2*r2)*h/3 然后以h进行二分 代码如下: #include<iostream>#include<algorithm>#include<cstring>#include<stack>#includ

poj3468(线段树成段更新模板题)

题意:包括两个操作:1、将[a.b]上的数字加上v;2、查询区间[a,b]上的和 下面的介绍是下解题思路: 首先介绍  lazy-tag思想:用一个变量记录每一个线段树节点的变化值,当这部分线段的一致性被破坏我们就将这个变化值传递给子区间,大大增加了线段树的效率。 比如现在需要对[a,b]区间值进行加c操作,那么就从根节点[1,n]开始调用update函数进行操作,如果刚好执行到一个子节点,

hdu1394(线段树点更新的应用)

题意:求一个序列经过一定的操作得到的序列的最小逆序数 这题会用到逆序数的一个性质,在0到n-1这些数字组成的乱序排列,将第一个数字A移到最后一位,得到的逆序数为res-a+(n-a-1) 知道上面的知识点后,可以用暴力来解 代码如下: #include<iostream>#include<algorithm>#include<cstring>#include<stack>#in

hdu1689(线段树成段更新)

两种操作:1、set区间[a,b]上数字为v;2、查询[ 1 , n ]上的sum 代码如下: #include<iostream>#include<algorithm>#include<cstring>#include<stack>#include<queue>#include<set>#include<map>#include<stdio.h>#include<stdl

嵌入式QT开发:构建高效智能的嵌入式系统

摘要: 本文深入探讨了嵌入式 QT 相关的各个方面。从 QT 框架的基础架构和核心概念出发,详细阐述了其在嵌入式环境中的优势与特点。文中分析了嵌入式 QT 的开发环境搭建过程,包括交叉编译工具链的配置等关键步骤。进一步探讨了嵌入式 QT 的界面设计与开发,涵盖了从基本控件的使用到复杂界面布局的构建。同时也深入研究了信号与槽机制在嵌入式系统中的应用,以及嵌入式 QT 与硬件设备的交互,包括输入输出设

让树莓派智能语音助手实现定时提醒功能

最初的时候是想直接在rasa 的chatbot上实现,因为rasa本身是带有remindschedule模块的。不过经过一番折腾后,忽然发现,chatbot上实现的定时,语音助手不一定会有响应。因为,我目前语音助手的代码设置了长时间无应答会结束对话,这样一来,chatbot定时提醒的触发就不会被语音助手获悉。那怎么让语音助手也具有定时提醒功能呢? 我最后选择的方法是用threading.Time

usaco 1.3 Prime Cryptarithm(简单哈希表暴搜剪枝)

思路: 1. 用一个 hash[ ] 数组存放输入的数字,令 hash[ tmp ]=1 。 2. 一个自定义函数 check( ) ,检查各位是否为输入的数字。 3. 暴搜。第一行数从 100到999,第二行数从 10到99。 4. 剪枝。 代码: /*ID: who jayLANG: C++TASK: crypt1*/#include<stdio.h>bool h

uva 10387 Billiard(简单几何)

题意是一个球从矩形的中点出发,告诉你小球与矩形两条边的碰撞次数与小球回到原点的时间,求小球出发时的角度和小球的速度。 简单的几何问题,小球每与竖边碰撞一次,向右扩展一个相同的矩形;每与横边碰撞一次,向上扩展一个相同的矩形。 可以发现,扩展矩形的路径和在当前矩形中的每一段路径相同,当小球回到出发点时,一条直线的路径刚好经过最后一个扩展矩形的中心点。 最后扩展的路径和横边竖边恰好组成一个直