摘要
本文簡單介紹Hi3861WiFi操作,怎么連接到熱點,查看IP,ping服務器等。適合群體
適用于潤和Hi3861開發板的開發。1、AT指令操作WiFi
我們可以使用AT指令進行Hi3861 WiFi操作,連接熱點、ping服務器等。
但是很多時候,我們需要實現開機后自動連接到某個熱點,光靠AT指令不行。
Hi3861 為我們提供了WiFi操作的相關API,方便我們編寫代碼,實現熱點連接。
2、代碼實現
先直接上代碼和操作演示,跟我們最早的hello world代碼一樣,在app下新增業務demo_wifi_sta,其中demo_wifi_sta.c為業務代碼,BUILD.gn為編譯腳本,具體規劃目錄結構如下:
其中BUILD.gn文件內容如下:
static_library("demo_wifi_sta") {
sources = [
"demo_wifi_sta.c"
]
include_dirs = [
"http://utils/native/lite/include",
"http://kernel/liteos_m/components/cmsis/2.0",
"http://base/iot_hardware/peripheral/interfaces/kits",
"http://device/soc/hisilicon/hi3861v100/hi3861_adapter/hals/communication/wifi_lite/wifiservice",
"http://device/soc/hisilicon/hi3861v100/hi3861_adapter/kal",
"http://device/soc/hisilicon/hi3861v100/sdk_liteos/third_party/lwip_sack/include",
]
}
向右滑動查看完整代碼
hi_wifi_start_sta函數:設置WiFi參數、掃描熱點
int hi_wifi_start_sta(void)
{
int ret;
char ifname[WIFI_IFNAME_MAX_SIZE + 1] = {0};
int len = sizeof(ifname);
const unsigned char wifi_vap_res_num = APP_INIT_VAP_NUM;
const unsigned char wifi_user_res_num = APP_INIT_USR_NUM;
unsigned int num = WIFI_SCAN_AP_LIMIT;
//這里不需要重復進行WiFi init,因為系統啟動后就自己會做WiFi init
printf("_______>>>>>>>>>> %s %d ", __FILE__, __LINE__);
ret = hi_wifi_init(wifi_vap_res_num, wifi_user_res_num);
if (ret != HISI_OK) {
return -1;
}
ret = hi_wifi_sta_start(ifname, &len);
if (ret != HISI_OK) {
return -1;
}
/* register call back function to receive wifi event, etc scan results event,
* connected event, disconnected event.
*/
ret = hi_wifi_register_event_callback(wifi_wpa_event_cb);
if (ret != HISI_OK) {
printf("register wifi event callback failed ");
}
/* acquire netif for IP operation */
g_lwip_netif = netifapi_netif_find(ifname);
if (g_lwip_netif == NULL) {
printf("%s: get netif failed ", __FUNCTION__);
return -1;
}
/* 開始掃描附件的WiFi熱點 */
ret = hi_wifi_sta_scan();
if (ret != HISI_OK) {
return -1;
}
sleep(5); /* sleep 5s, waiting for scan result. */
hi_wifi_ap_info *pst_results = malloc(sizeof(hi_wifi_ap_info) * WIFI_SCAN_AP_LIMIT);
if (pst_results == NULL) {
return -1;
}
//把掃描到的熱點結果存儲起來
ret = hi_wifi_sta_scan_results(pst_results, &num);
if (ret != HISI_OK) {
free(pst_results);
return -1;
}
//打印掃描到的所有熱點
for (unsigned int loop = 0; (loop < num) && (loop < WIFI_SCAN_AP_LIMIT); loop++) {
printf("SSID: %s ", pst_results[loop].ssid);
}
free(pst_results);
/* 開始接入熱點 */
ret = hi_wifi_start_connect();
if (ret != 0) {
return -1;
}
return 0;
}
向右滑動查看完整代碼
連接熱點:
int hi_wifi_start_connect(void)
{
int ret;
errno_t rc;
hi_wifi_assoc_request assoc_req = {0};
/* copy SSID to assoc_req */
rc = memcpy_s(assoc_req.ssid, HI_WIFI_MAX_SSID_LEN + 1, "RedmiK40", 8); /* 9:ssid length */
if (rc != EOK) {
return -1;
}
//熱點加密方式
assoc_req.auth = HI_WIFI_SECURITY_WPA2PSK;
/* 熱點密碼 */
memcpy(assoc_req.key, "07686582488", 11);
ret = hi_wifi_sta_connect(&assoc_req);
if (ret != HISI_OK) {
return -1;
}
return 0;
}
向右滑動查看完整代碼
熱點連接結果回調函數
void wifi_wpa_event_cb(const hi_wifi_event *hisi_event)
{
if (hisi_event == NULL)
return;
switch (hisi_event->event) {
case HI_WIFI_EVT_SCAN_DONE:
printf("WiFi: Scan results available ");
break;
case HI_WIFI_EVT_CONNECTED:
printf("WiFi: Connected ");
netifapi_dhcp_start(g_lwip_netif);
break;
case HI_WIFI_EVT_DISCONNECTED:
printf("WiFi: Disconnected ");
netifapi_dhcp_stop(g_lwip_netif);
hi_sta_reset_addr(g_lwip_netif);
break;
case HI_WIFI_EVT_WPS_TIMEOUT:
printf("WiFi: wps is timeout ");
break;
default:
break;
}
}
向右滑動查看完整代碼
hi_sta_reset_addr:重新復位sta的地址、網關等參數。
/* clear netif's ip, gateway and netmask */
void hi_sta_reset_addr(struct netif *pst_lwip_netif)
{
ip4_addr_t st_gw;
ip4_addr_t st_ipaddr;
ip4_addr_t st_netmask;
if (pst_lwip_netif == NULL) {
printf("hisi_reset_addr::Null param of netdev ");
return;
}
IP4_ADDR(&st_gw, 0, 0, 0, 0);
IP4_ADDR(&st_ipaddr, 0, 0, 0, 0);
IP4_ADDR(&st_netmask, 0, 0, 0, 0);
netifapi_netif_set_addr(pst_lwip_netif, &st_ipaddr, &st_netmask, &st_gw);
}
向右滑動查看完整代碼
3、WiFi相關API
Hi3861 提供了非常多的wifi相關API,主要文件是 hi_wifi_api.h,我們這里只列舉最重要的幾個API(1)開啟STA
int hi_wifi_sta_start(char *ifname, int *len);
向右滑動查看完整代碼
(2)停止STA
int hi_wifi_sta_stop(void);
向右滑動查看完整代碼
(3)掃描附件的熱點
int hi_wifi_sta_scan(void);
向右滑動查看完整代碼
(4)連接熱點
int hi_wifi_sta_connect(hi_wifi_assoc_request *req);
向右滑動查看完整代碼
其中hi_wifi_assoc_request *req 結構的定義如下:
typedef struct {
char ssid[HI_WIFI_MAX_SSID_LEN + 1]; /**< SSID. CNcomment: SSID 只支持ASCII字符.CNend */
hi_wifi_auth_mode auth; /**< Authentication mode. CNcomment: 認證類型.CNend */
char key[HI_WIFI_MAX_KEY_LEN + 1]; /**< Secret key. CNcomment: 秘鑰.CNend */
unsigned char bssid[HI_WIFI_MAC_LEN]; /**< BSSID. CNcomment: BSSID.CNend */
hi_wifi_pairwise pairwise; /**< Encryption type. CNcomment: 加密方式,不需指定時置0.CNend */
} hi_wifi_assoc_request;
向右滑動查看完整代碼
這里需要注意的是,通常加密方式是:HI_WIFI_SECURITY_WPA2PSK
例如我家的熱點的連接方式的代碼實現如下:
int hi_wifi_start_connect(void)
{
int ret;
errno_t rc;
hi_wifi_assoc_request assoc_req = {0};
/* copy SSID to assoc_req */
rc = memcpy_s(assoc_req.ssid, HI_WIFI_MAX_SSID_LEN + 1, "RedmiK40", 8); /* 9:ssid length */
if (rc != EOK) {
return -1;
}
//熱點加密方式
assoc_req.auth = HI_WIFI_SECURITY_WPA2PSK;
/* 熱點密碼 */
memcpy(assoc_req.key, "07686582488", 11);
ret = hi_wifi_sta_connect(&assoc_req);
if (ret != HISI_OK) {
return -1;
}
return 0;
}
向右滑動查看完整代碼
本小節文章就到這里了,后續文章會持續更新,歡迎大家持續關注哦~
原文標題:OpenHarmony輕量系統開發【9】WiFi之STA模式連接熱點
文章出處:【微信公眾號:HarmonyOS官方合作社區】歡迎添加關注!文章轉載請注明出處。
審核編輯:湯梓紅
-
服務器
+關注
關注
12文章
9123瀏覽量
85324 -
WIFI
+關注
關注
81文章
5296瀏覽量
203571 -
熱點
+關注
關注
0文章
11瀏覽量
2526 -
Hi3861
+關注
關注
1文章
59瀏覽量
6491
原文標題:OpenHarmony輕量系統開發【9】WiFi之STA模式連接熱點
文章出處:【微信號:HarmonyOS_Community,微信公眾號:電子發燒友開源社區】歡迎添加關注!文章轉載請注明出處。
發布評論請先 登錄
相關推薦
評論