1 AirDrop (UIActivityViewController類)
創(chuàng)新互聯(lián)建站主要從事成都網(wǎng)站制作、網(wǎng)站設(shè)計、網(wǎng)頁設(shè)計、企業(yè)做網(wǎng)站、公司建網(wǎng)站等業(yè)務(wù)。立足成都服務(wù)徐州,10年網(wǎng)站建設(shè)經(jīng)驗,價格優(yōu)惠、服務(wù)專業(yè),歡迎來電咨詢建站服務(wù):13518219792
功能:實現(xiàn)iOS設(shè)備間的文件和數(shù)據(jù)分享。AirDrop使用藍(lán)牙來掃描周圍的設(shè)備,當(dāng)兩臺設(shè)備通過藍(lán)牙建立起了連接,考慮到更快速的數(shù)據(jù)傳輸,它就會創(chuàng)建點對點的WiFi網(wǎng)絡(luò)來連接兩部iOS 設(shè)備。但并不意味著為了使用AirDrop而需要把設(shè)備連接至WiFi網(wǎng)絡(luò)。
傳輸方式:藍(lán)牙、WiFi
支持系統(tǒng):iOS
2 GameKit 框架
功能:GameKit主要是完成iOS設(shè)備間聯(lián)網(wǎng)的相關(guān)功能,包括藍(lán)牙和Internet兩種方式。
傳輸方式:藍(lán)牙、WiFi
支持系統(tǒng):iOS
3 MultipeerConnectivity 框架
功能:利用Multipeer Connectivity框架,即使在沒有連接到WiFi(WLAN)或移動網(wǎng)絡(luò)(xG)的情況下,距離較近的Apple設(shè)備(iMac/iPad/iPhone)之間可基于藍(lán)牙和WiFi(P2P WiFi)技術(shù)進(jìn)行發(fā)現(xiàn)和連接實現(xiàn)近場通信。
傳輸方式:藍(lán)牙、WiFi
支持系統(tǒng):iOS
4 ExternalAccessory 框架
功能:External Accessory Framework提供了配件連接iOS設(shè)備的通道。開發(fā)者可以通過它來開發(fā)連接配件的app。配件可以通過30pin、藍(lán)牙、USB的方式連接iOS設(shè)備。
傳輸方式:藍(lán)牙、WiFi
支持系統(tǒng):iOS
5 CoreBluetooth 框架
功能:藍(lán)牙4.0協(xié)議之間信息傳輸,支持iOS和Android設(shè)備。
傳輸方式:藍(lán)牙
支持系統(tǒng):iOS、Android
6 Socket
功能:通過TCP或UDP進(jìn)行相同局域網(wǎng)內(nèi)信息傳輸,支持iOS和Android設(shè)備。
傳輸方式:WiFi
支持系統(tǒng):iOS、Android
7 Bonjour
功能:Bonjour是一種能夠自動查詢接入網(wǎng)絡(luò)中的設(shè)備或應(yīng)用程序的協(xié)議。Bonjour 抽象掉 ip 和 port 的概念,讓我們聚焦于更容易為人類思維理解的 service。通過 Bonjour,一個應(yīng)用程序 publish 一個網(wǎng)絡(luò)服務(wù) service,然后網(wǎng)絡(luò)中的其他程序就能自動發(fā)現(xiàn)這個 service,從而可以向這個 service 查詢其 ip 和 port,然后通過獲得的 ip 和 port 建立 socket 鏈接進(jìn)行通信,支持iOS和Android設(shè)備。
傳輸方式:WiFi
支持系統(tǒng):iOS、Android
8 AllJoyn
功能:AllJoyn,由高通公司主導(dǎo)的高創(chuàng)新中心的開源項目開發(fā)的,主要用于近距離無線傳輸,通過WiFi或藍(lán)牙技術(shù),定位和點對點文件傳輸。支持平臺:RTOS、Arduino、Linux、Android、iOS、Windows、Mac。
傳輸方式:藍(lán)牙、WiFi
支持系統(tǒng):RTOS、Arduino、Linux、Android、iOS、Windows、Mac
通過官方的API 可以獲取到wifi的信息,實現(xiàn)代碼:
-?(id)fetchSSIDInfo?{??
NSArray?*ifs?=?(__bridge_transfer?id)CNCopySupportedInterfaces();??
NSLog(@"Supported?interfaces:?%@",?ifs);??
id?info?=?nil;??
for?(NSString?*ifnam?in?ifs)?{??
info?=?(__bridge_transfer?id)CNCopyCurrentNetworkInfo((__bridge?CFStringRef)ifnam);??
NSLog(@"%@?=?%@",?ifnam,?info);??
if?(info??[info?count])?{?break;?}??
}??
return?info;??
}
至于開關(guān)wifi,是一個用戶的操作, 在非越獄的機器上,第三方的應(yīng)用是沒法實現(xiàn)這功能的。
最近遇到一個比較奇葩的需求:App與硬件通過WiFi LAN通信, 同時App需要與服務(wù)器通過3G/4G WAN通信,如下圖:
眾所周知,手機同時打開WiFi和3G時候,會優(yōu)先走WiFi。這個該如何實現(xiàn)呢?市面上有一個極路客APP已經(jīng)實現(xiàn)此方案,網(wǎng)上各種搜索資料,出現(xiàn)一個 Multipath TCP概念 ,但是這個系統(tǒng)沒有API,瞬間抓狂,直接查看極路客APP與他們硬件連接的WIFI,發(fā)現(xiàn)與我們平時WiFi不一樣,DNS沒有。
藍(lán)牙是比較簡單的 使用蘋果自帶的 CoreBluetooth 就可以 ,至于wifi 現(xiàn)在貌似都是私有API了,上架可能會遇到問題,如果是企業(yè)帳號 則可以使用NSNetService類 和CFNetServices C API實現(xiàn)設(shè)備的發(fā)現(xiàn)、連接和Bonjour services.通過Socket實現(xiàn)基于TCP/IP協(xié)議網(wǎng)絡(luò)通信。推薦 CocoaAsyncSocket 一個Socket的開源框架
作為一個開發(fā)者,有一個學(xué)習(xí)的氛圍跟一個交流圈子特別重要,這是一個我的iOS交流群: 812157648 ,不管你是小白還是大牛歡迎入駐 ,分享BAT,阿里面試題、面試經(jīng)驗,討論技術(shù), 大家一起交流學(xué)習(xí)成長!
iOS 13 以后
獲取WiFi名稱,必須要先允許獲取定位信息
原文地址: ;request_id=160741070019215668868668biz_id=0utm_medium=distribute.pc_search_result.none-task-blog-2 all first_rank_v2~rank_v29-6-110481171.pc_search_result_cacheutm_term=iOS%E5%BC%80%E5%8F%91
遍歷UIStatusBar獲取信號類型
- (void)getNetworkType
{
UIApplication *app = [UIApplication sharedApplication];
NSArray *subviews = [[[app valueForKeyPath:@"statusBar"] valueForKeyPath:@"foregroundView"] subviews];
for (id subview in subviews) {
if ([subview isKindOfClass:NSClassFromString(@"UIStatusBarDataNetworkItemView")]) {
int networkType = [[subview valueForKeyPath:@"dataNetworkType"] intValue];
switch (networkType) {
case 0:
NSLog(@"NONE");
break;
case 1:
NSLog(@"2G");
break;
case 2:
NSLog(@"3G");
break;
case 3:
NSLog(@"4G");
break;
case 5:
{
NSLog(@"WIFI");
}
break;
default:
break;
}
}
}
}
- (void)getSignalStrength{
UIApplication *app = [UIApplication sharedApplication];
NSArray *subviews = [[[app valueForKey:@"statusBar"] valueForKey:@"foregroundView"] subviews];
NSString *dataNetworkItemView = nil;
for (id subview in subviews) {
if([subview isKindOfClass:[NSClassFromString(@"UIStatusBarDataNetworkItemView") class]]) {
dataNetworkItemView = subview;
break;
}
}
int signalStrength = [[dataNetworkItemView valueForKey:@"_wifiStrengthBars"] intValue];
NSLog(@"signal %d", signalStrength);
}