相关知识点
- WiFi的工作模式
- AP模式:热点模式,提供无线接入服务,允许其它无线设备接入,提供数据访问,一般的无线路由/网桥工作在该模式。
- STA模式:类似于无线终端,本身并不接受其他设备的接入,它可以连接到AP,一般无线网卡即工作在该模式。
- Harmony OS的WiFi相关API头文件位于
foundationcommunicationinterfaceskitswifi_litewifiservice
目录,该目录下有9个文件;wifi_device.h
中定义的是STA模式的主要接口,例如扫描其他热点、添加热点配置(热点名称、密码等)、连接其他热点;wifi_hotspot.h
中定义的是AP模式的主要接口,例如设置热点信息(热点名称、密码等)、查询连接的设备列表;wifi_hotspot_config.h
中定义了设置和获取当前工作在2.4G或者5G频段的接口SetBand
和GetBand
;- 另外6个文件中定义了上述接口相关的类型,例如扫描结果、热点配置、热点连接状态等;
STA模式编程指南
STA模式API

扫描WiFi热点
在Harmony OS上STA模式扫描其他WiFi热点,需要注意以下事项
- 功能相关接口都有
WifiErrorCode
类型的返回值:- 需要接收并判断返回值是否为
WIFI_SUCCESS
,用于确认是否调用成功; - 不为
WIFI_SUCCESS
表示失败,通过枚举值查找错误原因;
- 需要接收并判断返回值是否为
EnableWifi
接口使能STA模式之前:- 需要使用
RegisterWifiEvent
接口,向系统注册状态监听函数,用于接收状态通知,STA模式需要绑定如下两个回调函数;OnWifiScanStateChanged
用于绑定扫描状态监听函数,该回调函数有两个参数state
和size
;state
表示扫描状态,取值为0和1,1表示扫描动作完成;编程时可以与WifiEventState
枚举值的WIFI_STATE_NOT_AVALIABLE
,WIFI_STATE_AVALIABLE
进行比较,避免魔法数字;
size
表示扫描到的热点个数;OnWifiConnectionChanged
用于绑定WiFi连接状态监听函数,该回调函数有两个参数state
和info
;state
表示WiFi连接状态,连接成功是WIFI_STATE_AVALIABLE
值为1,连接失败时WIFI_STATE_NOT_AVALIABLE
值为0;info
类型为WifiLinkedInfo*
,WifiLinkedInfo
有多个成员,包括ssid
,bssid
,rssi
,connState
,disconnectedReason
;
- 需要使用
Scan
接口只是触发扫描动作,并不会等到扫描完成才返回;- 调用
Scan
接口进行扫描之前,- 需要确保已经调用
EnableWifi
接口,并成功使能了STA模式;
- 需要确保已经调用
- 扫描状态监听回调函数内,不能直接调用
GetScanInfoList
函数(否则会有运行时异常报错),正确用法:- 可以在状态更新回调函数中更新全局状态变量,另外一个线程中轮训状态变量,这种方式实现起来比较简单;但需要保证更新和查询操作的原子性(可以使用gcc内置原子操作函数),逻辑才是严格正确的;
- 或者使用信号量进行通知,这种方式更好一些,更优雅;
- 扫描完成后要及时调用
GetScanInfoList
函数获取扫描结果;- 如果间隔时间太长(例如5秒以上),可能会无法获得上次扫描结果;
GetScanResult
函数有两个参数:- 第一个参数
result
指向用于存放结果的数组,需要大于等于WIFI_SCAN_HOTSPOT_LIMIT
, - 第二个参数
size
类型为指针是为了内部能够修改它的值,返回后size指向的值是实际搜索到的热点个数;
- 第一个参数
- 调用
GetScanResult
函数前,第二个参数size
指向的实际值不能为0,否则会包参数错误;
DisableWifi
关闭STA模式;
连接WiFi热点
在Harmony OS上STA模式连接其他WiFi热点,需要注意的事项和扫描WiFi热点类似,一下介绍差异的部分:
- 首先,需要使用
RegisterWifiEvent
接口,向系统注册状态监听函数,STA模式需要绑定两个回调; - 然后,通过
AddDeviceConfig
接口,向系统添加热点配置,它有两个参数;- 第一个参数
config
,类型为const WifiDeviceConfig*
,用于指定热点配置; - 第二个参数
result
,类型为int*
,用于操作成功时返回netId
;
- 第一个参数
- 连接热点使用
ConnectTo
接口,他有一个参数;netId
,类型为int
,应该使用AddDeviceConfig
接口调用成功之后result
参数得到值填充;
ConnectTo
是同步的,连接成功失败会通过返回值体现;- 同时,系统也会通过回调函数通知应用代码;
- 连接成功后,需要调用DHCP客户端,从热点获取IP地址;
struct netif* iface = netifapi_netif_find("wlan0");
获取STA模式的网络接口err_t netifapi_dhcp_start(struct netif*)
接口,启动DHCP客户端;
- 断开热点使用
Disconnect
接口,无需参数,端口之前需要:err_t netifapi_dhcp_stop(struct netif*)
接口,停止DHCP客户端;
- 删除热点配置使用
RemoveDevice
,参数和ConnectTo
类似,- 需要使用
AddDeviceConfig
接口调用成功之后result
参数得到值填充;
- 需要使用
AP模式编程指南
AP模式API接口
创建WiFi热点
在Harmony OS上创建WiFi热点,通用有一些事项需要注意:
- 首先,需要使用
RegisterWifiEvent
接口,向系统注册扫描状态监听函数,用于接收扫描状态通知,AP模式需要绑定三个函数;OnHotspotStaJoin
回调函数,其他设备连上当前热点时会被调用,参数StationInfo* info
,其中包含macAddress
和disconnectedReason
;OnHotspotStaLeave
回调函数,其他设备断开当前热点时会被调用,参数StationInfo* info
;OnHotspotStateChanged
回调函数,当热点本身状态变化时会被调用,参数int state
表示热点状态;
- 然后,通过
SetHotspotConfig
接口,向系统设置当前热点配置信息; - 是用
EnableHotspot
接口,开启热点,无需参数; - 热点开启成功之后,需要启动DHCP服务端,Hi3861上使用如下SDK接口;
- 使用
DisableHotspot
接口关闭热点; - 使用
UnRegisterWifiEvent
接口解除事件监听;
有两种方法可以编译此目录下的样例程序:
- 前两章中的方法——将当前目录下的
*.c
文件和BUILD.gn
拷贝到openharmony源码的applicationssamplewifi-iotappiothardware
目录下;- 再修改openharmony源码的
applicationssamplewifi-iotappBUILD.gn
文件,将其中的features
改为:iothardware:wifi_demo
; - 再修改
applicationssamplewifi-iotappiothardwareBUILD.gn
文件,决定需要编译哪个.c
文件; - 在openharmony源码顶层目录执行:
python build.py wifiiot
- 再修改openharmony源码的
- 可以将本仓整体拷贝到openharmony源码树下,和
applications
同级;- 修改openharmony源码的
buildliteproductwifiiot.json
文件,将其中的://applications/sample/wifi-iot/app
替换为://HarmonyOS-IoT-Application-Development:app
- 修改openharmony源码的
阅读全文
下载说明:
1、本站所有资源均从互联网上收集整理而来,仅供学习交流之用,因此不包含技术服务请大家谅解!
2、本站不提供任何实质性的付费和支付资源,所有需要积分下载的资源均为网站运营赞助费用或者线下劳务费用!
3、本站所有资源仅用于学习及研究使用,您必须在下载后的24小时内删除所下载资源,切勿用于商业用途,否则由此引发的法律纠纷及连带责任本站和发布者概不承担!
4、本站站内提供的所有可下载资源,本站保证未做任何负面改动(不包含修复bug和完善功能等正面优化或二次开发),但本站不保证资源的准确性、安全性和完整性,用户下载后自行斟酌,我们以交流学习为目的,并不是所有的源码都100%无错或无bug!如有链接无法下载、失效或广告,请联系客服处理!
5、本站资源除标明原创外均来自网络整理,版权归原作者或本站特约原创作者所有,如侵犯到您的合法权益,请立即告知本站,本站将及时予与删除并致以最深的歉意!
6、如果您也有好的资源或教程,您可以投稿发布,成功分享后有站币奖励和额外收入!
7、如果您喜欢该资源,请支持官方正版资源,以得到更好的正版服务!
8、请您认真阅读上述内容,注册本站用户或下载本站资源即您同意上述内容!
原文链接:https://www.1024c.cn/archives/21265,转载请注明出处。
1、本站所有资源均从互联网上收集整理而来,仅供学习交流之用,因此不包含技术服务请大家谅解!
2、本站不提供任何实质性的付费和支付资源,所有需要积分下载的资源均为网站运营赞助费用或者线下劳务费用!
3、本站所有资源仅用于学习及研究使用,您必须在下载后的24小时内删除所下载资源,切勿用于商业用途,否则由此引发的法律纠纷及连带责任本站和发布者概不承担!
4、本站站内提供的所有可下载资源,本站保证未做任何负面改动(不包含修复bug和完善功能等正面优化或二次开发),但本站不保证资源的准确性、安全性和完整性,用户下载后自行斟酌,我们以交流学习为目的,并不是所有的源码都100%无错或无bug!如有链接无法下载、失效或广告,请联系客服处理!
5、本站资源除标明原创外均来自网络整理,版权归原作者或本站特约原创作者所有,如侵犯到您的合法权益,请立即告知本站,本站将及时予与删除并致以最深的歉意!
6、如果您也有好的资源或教程,您可以投稿发布,成功分享后有站币奖励和额外收入!
7、如果您喜欢该资源,请支持官方正版资源,以得到更好的正版服务!
8、请您认真阅读上述内容,注册本站用户或下载本站资源即您同意上述内容!
原文链接:https://www.1024c.cn/archives/21265,转载请注明出处。
评论0