From 64fe26659ec15a5fe745fa7d682313d81e31cdee Mon Sep 17 00:00:00 2001 From: m0_75226990 Date: Sat, 26 Nov 2022 14:20:08 +0800 Subject: [PATCH] =?UTF-8?q?fix:=20=E5=B0=86=E8=8E=B7=E5=8F=96wifi=E4=BF=A1?= =?UTF-8?q?=E6=81=AF=E6=8E=A5=E5=8F=A3=E7=9A=84=E8=BF=94=E5=9B=9E=E5=80=BC?= =?UTF-8?q?=E6=94=B9=E6=88=90=E5=9B=9E=E8=B0=83=EF=BC=8C=E5=A2=9E=E5=8A=A0?= =?UTF-8?q?readme=E6=8E=A5=E5=8F=A3=E4=BD=BF=E7=94=A8=E7=A4=BA=E4=BE=8B?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../WifiInfomation/wifiInfomation.vue | 17 ++-- uni_modules/uni-wifiinformation/readme.md | 86 ++++++++++++++++++- .../utssdk/app-ios/index.uts | 30 +++++-- 3 files changed, 116 insertions(+), 17 deletions(-) diff --git a/pages/SystemAPI/WifiInfomation/wifiInfomation.vue b/pages/SystemAPI/WifiInfomation/wifiInfomation.vue index fb97f08..9d338ae 100644 --- a/pages/SystemAPI/WifiInfomation/wifiInfomation.vue +++ b/pages/SystemAPI/WifiInfomation/wifiInfomation.vue @@ -27,14 +27,15 @@ /* iOS12之后获取wifi信息需要获取系统定位权限,否则获取到的wifi信息为空 */ requestLocationPromise(function(res) { if (res["success"] == true) { - let wifiInfo = getCurrentWifiInfo() - if (wifiInfo != null) { - console.log(wifiInfo) - uni.showToast({ - title: "当前wifi信息获取成功", - icon: 'none' - }) - } + getCurrentWifiInfo({ + success:function(res){ + console.log(res) + uni.showToast({ + title: `当前wifi信息: interface: ${res.wifiInterface}, SSID: ${res.SSID}, BSSID: ${res.BSSID}` , + icon: 'none' + }) + } + }) } }) }, diff --git a/uni_modules/uni-wifiinformation/readme.md b/uni_modules/uni-wifiinformation/readme.md index b364844..95863ce 100644 --- a/uni_modules/uni-wifiinformation/readme.md +++ b/uni_modules/uni-wifiinformation/readme.md @@ -1,5 +1,83 @@ # uni-currentwifiinformation -### 开发文档 -[UTS 语法](https://uniapp.dcloud.net.cn/tutorial/syntax-uts.html) -[UTS 原生插件](https://uniapp.dcloud.net.cn/plugin/uts-plugin.html) -[Hello UTS](https://gitcode.net/dcloud/hello-uts/-/tree/dev) \ No newline at end of file + +## 使用文档 + +```ts + +import { getCurrentWifiInfo, requestLocationPromise } from '@/uni_modules/uni-wifiinformation'; + +// 获取系统定位权限 +requestLocationPromise(function(res){ + console.log(res) + uni.showToast({ + title: res["message"], + icon: 'none' + }) +}) + +// 获取手机当前连接的wifi信息 +getCurrentWifiInfo({ + success:function(res){ + console.log(res) + uni.showToast({ + title: `当前wifi信息: interface: ${res.wifiInterface}, SSID: ${res.SSID}, BSSID: ${res.BSSID}` , + icon: 'none' + }) + } +}) + +// 注意:iOS12之后获取wifi信息需要获取系统定位权限,否则获取到的wifi信息为空 +// 所以建议在获取wifi信息之前,先调用获取系统定位权限的接口 +// 示例如下: +requestLocationPromise(function(res) { + if (res["success"] == true) { + getCurrentWifiInfo({ + success:function(res){ + console.log(res) + uni.showToast({ + title: `当前wifi信息: interface: ${res.wifiInterface}, SSID: ${res.SSID}, BSSID: ${res.BSSID}` , + icon: 'none' + }) + } + }) + } +}) + + +``` + + + +### 参数 +#### getCurrentWifiInfo + +Object object + +|属性|类型|必填|说明| +|----|---|----|----| +|success|function|否|接口调用成功的回调函数| +|fail|function|否|接口调用失败的回调函数| +|complete|function|否|接口调用结束的回调函数(调用成功、失败都会执行)| + + + +object.success 回调函数 + + +|属性|类型|说明| +|----|---|----| +|wifiInterface|string|当前手机连接wifi的interface,如 en0| +|SSID|string|当前手机连接wifi的SSID,即wifi名称| +|BSSID|string|当前手机连接wifi的BSSID| + + +#### requestLocationPromise + +completion UTSCallback + +object 回调函数 + +|属性|类型|说明| +|----|---|----| +|success|bool|是否获取成功| +|message|string|描述信息| diff --git a/uni_modules/uni-wifiinformation/utssdk/app-ios/index.uts b/uni_modules/uni-wifiinformation/utssdk/app-ios/index.uts index 6f9bf6c..b24ff6b 100644 --- a/uni_modules/uni-wifiinformation/utssdk/app-ios/index.uts +++ b/uni_modules/uni-wifiinformation/utssdk/app-ios/index.uts @@ -3,6 +3,16 @@ import { CaptiveNetwork, kCNNetworkInfoKeySSID, kCNNetworkInfoKeyBSSID } from 'S import { NSArray, NSDictionary } from 'Foundation'; import { CFString } from 'CoreFoundation'; + +/** + * 定义 接口参数 + */ +type GetWifiInfoOptions = { + success?: (res: object) => void; + fail?: (res: object) => void; + complete?: (res: object) => void; +}; + class CurrentWifiInfo { wifiInterface: string = "" @@ -89,13 +99,12 @@ export function requestLocationPromise (completion: UTSCallback) { locationPromiseService.requestPromise(completion) } -export function getCurrentWifiInfo (): CurrentWifiInfo | null { +export function getCurrentWifiInfo (option: GetWifiInfoOptions) { let arr = CNCopySupportedInterfaces() if (arr != null) { let list = arr! as NSArray - let wifiInfo = new CurrentWifiInfo("", "", "") let index = 0 - let array = [1, 2, 3] + let wifiInfo = new CurrentWifiInfo("", "", "") while (index < list.count) { let item = list[index] let interfaceName = item as string @@ -118,9 +127,20 @@ export function getCurrentWifiInfo (): CurrentWifiInfo | null { } if (wifiInfo.BSSID.length > 0 && wifiInfo.SSID.length > 0) { - return wifiInfo + let res = { + wifiInterface: wifiInfo.wifiInterface, + SSID: wifiInfo.SSID, + BSSID: wifiInfo.BSSID + } + option.success?.(res) + option.complete?.(res) + }else { + option.fail?.({message: "current wifi is null"}) + option.complete?.({message: "current wifi is null"}) } + }else { + option.fail?.({message: "current wifi is null"}) + option.complete?.({message: "current wifi is null"}) } - return null } -- GitLab