WiFi 智能配置方案的原理介绍

前言

物联网大行其道,WiFi 模块的使用也是越来越多,在没有显示屏的 WiFi 设备上,要配置它们连接 AP,就需要 WiFi 智能配置功能:

即通过手机等设备发送带有 WiFi 帐号和密码的数据包,WiFi 设备过滤和解析数据包来提取帐号和密码,使其获取 AP 的帐号和密码,继而连接 AP。


方案

当 WiFi 设备与无线 AP 没有建立连接前,因无线 AP 有加密机制(eg: wpa2、wpa、wep),所以设备无法从数据包的负载中提取有效数据。

既然 802.11 帧的数据负载加密了,我们可以从 802.11 帧的头部和 802.11 帧的长度中寻找可利用的线索。

1. 802.11 帧头部中的 Sequence Control 字段
该字段应用层无法修改,由系统内部自动维护,每发送一帧数据,该字段自动加 1。可以利用这个特性来判别数据帧的连续性。

2. 802.11 帧头部中的 Address1,Address2,Address3 三个目的地址字段
在 AP 模式下,三个地址字段的含义为 源 MAC 地址、BSSID(AP MAC地址)、目的 MAC 地址,详情请查看另一篇博文的介绍(请点击这里)。源 MAC 地址和 BSSID 应用层是不能修改的,但目的 MAC 地址是能够修改的

3. 802.11 帧的长度
802.11 帧的数据负载虽然加密了,但是 WiFi 设备在接收到 802.11 帧的时候能够获取该帧的数据长度,可以利用这个长度的变化来携带数据。

以上便是寻找到的线索,哪些能够被应用层修改,哪些能够被充分的利用起来。
所以通过以上的线索可以粗略的得出以下几种可行的方案,具体实现那又是另外一码事了。

方案一:
以广播或者组播的方式进行发送,利用 802.11 帧长度携带配置数据,以 802.11 帧头部中的 Sequence Control 字段做为配置数据前后关联性的序列号

方案二
以广播、组播或者单播的方式进行发送,利用 802.11 帧长度携带配置数据前后关联性的序列号以及配置数据。

  • 广播和组播的方式发送,设备端能够通过指定的 MAC 地址过滤无效帧,提高配置效率。
  • 单播方式发送,例如直接使用 UDP 把配置数据发送给路由器 IP 地址,这样理论上能降低环境中一半的帧数量,减少拥堵(因为目的地是路由器,所以路由器不会转发该包,广播和组播都会转发,但是设备端难于指定 MAC 地址来过滤无效帧了)

以下是单播方式发送数据给路由器的配置方案抓包截图:在这里插入图片描述

方案三
以组播的方式进行发送,利用组播地址特性对组播 MAC 地址的后三个字节进行控制来携带数据,体现在应用层就是把配置数据转换成指定的组播 IP 地址进行组播发送,即每次发送配置数据就转换一次组播地址。

上图一目了然,以下是该配置方案发送的组播包:
这里写图片描述
从图中可以看出:
目的 MAC 地址的第四个字节,表征的应该是配置数据的类型,诸如帐号或者密码等类型;
目的 MAC 地址的第五个字节,表征的应该是配置数据的序列号;
目的 MAC 地址的第六个字节,表征的应该是配置的数据。

Probe Request 方案
从其他地方了解到的,未经证实,但感觉可行。手机控制 WiFi 执行主动扫描,发送 Probe Request,猜测在帧体的 SSID 字段和 Vendor Specific 字段,填充编码信息(但不确定手机端能否调用接口修改这两个字段),设备接收并解析编码数据,获取 SSID 和密码

AP 热点方案
本方案跟本博文介绍的无关,即 WiFi 设备在智能配置阶段生成一个 AP 热点,手持设备连接该 AP 热点之后,传送需要接入的 AP 帐号和密码。


总结

方案一 和 方案二 :难点在于 WiFi 设备如何提取有效的配置数据,一个是识别哪些是配置数据帧,二个是接收到的配置数据帧中是否存在丢失的数据帧以及重复接收的数据帧

方案三 :手持设备构造配置数据和 WiFi 设备提取配置数据时,看上去比较简单易行,配置可靠。利用组播 MAC 地址的后三个字节中填充配置数据的前后关联性的序列号和配置数据,一帧配置包可以携带三个有效字节的数据,同时设备端可以很好的利用组播 MAC 地址的前三个固定的值 01:00:5E,过滤一些无用帧。

AP 热点方案 :是最可靠的方案,当环境无线网络非常拥堵时,前面几种方案配置成功的概率会大大降低,配置速度也会变慢,而 AP 热点方案不管环境无线网络如何拥堵,只要能够正常通信,就能够配置成功。

  • 1
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
WIFI232模块概述: 串口WiFi,内置天线,带屏蔽罩,被大量使用,适用于大流量通信,不考虑功耗的场合。 关于WIFI232家族: 硬件上,我们集成了MAC、射频收发单元、功率放大器等,加上天线,你就可以直接拿去用。 软件上,我们自带固件,内置WiFi协议、TCP/IP协议,你只需要简单的配置下我即可。 简单来说,我们做了很多事,而你,只需要通过一个UART接口来跟我沟通要做什么,我们就帮你实现。 我们会给你相应的配置命令(AT指令集),操作上,当然就像使用串口一样简单。 WiFi模块作为AP时的应用: 特点: 操作简单:会操作串口就会操控我(提供指令集;我是串口WIFI) 启动时间:6S。(市面上普通WIFI模块启动时间大都多于6S,部分甚至接近30S) 功耗:3.3V供电,170mA-300mA。(功耗偏大,适用于非电池供电等一些对功耗无要求的场合) 带屏蔽罩:对模块核心部分进行封包。(不少厂家没有加屏蔽措施) 适合做热点:可接入终端多,支持路由/桥接模式网络构架。(路由器AP方案) TCPB功能:支持2 x TCP功能,即可以同时支持2个网络连接。(市面上的普通模块没有这个功能) 演示视频: 功能: 方案:Marvell WiFi(路由器方案,硬件AP)、ARM 支持无线局域网标准:IEEE 802.11 b/g/n 支持WIFI加密方式和算法:WEP/WPA-PSK/WPA2-PSK/WAPI等 支持STA/AP/STA+AP共存工作模式(AP即WIFI热点;STA是WIFI终端)AP模式:可接入32个设备 STA模式:server端支持32个连接 AP+STA模式:具有路由功能,AP允许32个客户端连接 支持多种网络协议:TCP/UDP/ARP/ICMP/HTTP/DNS/DHCP 支持DHCP自动获取IP 支持AT+指令集及Web配置模块参数 支持透明/协议数据传输模式,1M缓存空间(用于TCP的缓存是4K) 支持串口分帧延迟和数据量设置 支持波特率可达460800bps,支持硬件流 支持以太网数据传输、PWM输出、GPIO控制 支持web升级固件 内置PA,57600波特率双向互传不丢包,轻松穿三层混泥土墙 通讯距离:外置3DB天线400米,内置天线150米。(开阔地;模块对传) 支持恢复出厂设置:通过拉低Reload IO口三秒即可恢复出厂设置,无须担心设置错误 支持路由/桥接模式网络构架(由路由器方案决定支持) 内建看门狗和心跳机制,保证在线能力 配套软件: WINDOWS、iOS、Android下的测试软件(方便你测试) iOS、Android通信源码(方便你借鉴) 实物购买链接:https://www.waveshare.net/shop/WIFI232-A.htm

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值