博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
关于获取当前网络是属于2G还是3G(极其简单)
阅读量:4115 次
发布时间:2019-05-25

本文共 2693 字,大约阅读时间需要 8 分钟。

中国的iphone网络是区分2G和3G,要想获取当前的网络状态一直没有一个好的方法,网上给的例子也不尽让人满意最近闲来无事,仔细的研究Apple提供的例子:Reachability

通过如下的代码:

[cpp] 
  1. Reachability *reach = [Reachability reachabilityWithHostName:@"www.apple.com"];  
  2. NSLog(@"%d", [reach currentReachabilityStatus]);   
  3. return;  

在currentReachabilityStatus函数中,我们注意到这样的输出:

[cpp] 
  1. static void PrintReachabilityFlags(SCNetworkReachabilityFlags flags, c*****t char* comment)  
  2. {  
  3. #if kShouldPrintReachabilityFlags  
  4. NSLog(@"Reachability Flag Status: %c%c %c%c%c%c%c%c%c %s\n",  
  5.      (flags & kSCNetworkReachabilityFlagsIsWWAN) ? 'W' : '-',   
  6.      (flags & kSCNetworkReachabilityFlagsReachable) ? 'R' : '-',  
  7.      (flags & kSCNetworkReachabilityFlagsTransientConnection) ? 't' : '-',  
  8.      (flags & kSCNetworkReachabilityFlagsConnectionRequired) ? 'c' : '-',  
  9.      (flags & kSCNetworkReachabilityFlagsConnectionOnTraffic) ? 'C' : '-',   
  10.      (flags & kSCNetworkReachabilityFlagsInterventionRequired) ? 'i' : '-',  
  11.      (flags & kSCNetworkReachabilityFlagsConnectionOnDemand) ? 'D' : '-',   
  12.      (flags & kSCNetworkReachabilityFlagsIsLocalAddress) ? 'l' : '-',  
  13.      (flags & kSCNetworkReachabilityFlagsIsDirect) ? 'd' : '-',  
  14.      comment   
  15.      );  
  16. #endif  
  17. }  

当是wifi的时候输出R

当是3G的时候输出Rt

当是联通2G或者是移动的时候输出Rtc

在头文件定义如下:

[cpp] 
  1. typedef enum   
  2. {   
  3.     NotReachable = 0,  
  4.     ReachableViaWiFi,   
  5.     ReachableVia3G,   
  6.     ReachableVia2G,//当前无法区分是联通的2G还是移动的2G  
  7. } NetworkStatus;  

因此我就是以这个为判断条件的,重写Reachability的函数:

[cpp] 
  1. - (NetworkStatus) networkStatusForFlags: (SCNetworkReachabilityFlags) flags  
  2. {  
  3.     if ((flags & kSCNetworkReachabilityFlagsReachable) == 0)  
  4.     {   
  5.          return NotReachable;  
  6.     }  
  7.     BOOL retVal = NotReachable;  
  8.     if ((flags & kSCNetworkReachabilityFlagsConnectionRequired) == 0)  
  9.     {   
  10.          // if target host is reachable and no connection is required  
  11.         // then we'll assume (for now) that your on Wi-Fi   
  12.         retVal = ReachableViaWiFi;  
  13.     }  
  14.     if (  
  15.         ((flags & kSCNetworkReachabilityFlagsConnectionOnDemand ) != 0) ||   
  16.         (flags & kSCNetworkReachabilityFlagsConnectionOnTraffic) != 0  
  17.     )  
  18.     {  
  19.         // ... and the connection is on-demand (or on-traffic) if the  
  20.         // calling application is using the CFSocketStream or higher APIs  
  21.          if ((flags & kSCNetworkReachabilityFlagsInterventionRequired) == 0)   
  22.         {   
  23.             // ... and no [user] intervention is needed   
  24.             retVal = ReachableViaWiFi;   
  25.         }   
  26.     }  
  27.     if ((flags & kSCNetworkReachabilityFlagsIsWWAN) == kSCNetworkReachabilityFlagsIsWWAN)   
  28.     {   
  29.         retVal = ReachableVia3G;  
  30.         if((flags & kSCNetworkReachabilityFlagsReachable) == kSCNetworkReachabilityFlagsReachable)   
  31.         {   
  32.             if ((flags & kSCNetworkReachabilityFlagsTransientConnection) == kSCNetworkReachabilityFlagsTransientConnection)   
  33.             {  
  34.                 retVal = ReachableVia3G;  
  35.                 if((flags & kSCNetworkReachabilityFlagsConnectionRequired) == kSCNetworkReachabilityFlagsConnectionRequired)   
  36.                 {  
  37.                     retVal = ReachableVia2G;  
  38.                 }  
  39.             }  
  40.         }   
  41.     }  
  42.     return retVal;  
  43. }  
这样就可以正确的区分是2G,3G,wifi网络,这只支持中国地区,其他地区未考虑。

作者:Rush.D.Xzj

欢迎转载 转载请注明来源

你可能感兴趣的文章
JavaScript函数式编程究竟是什么?
查看>>
21个极大提高开发效率的VS Code快捷键
查看>>
这些Vue3.0的最新技能你掌握了吗?
查看>>
5种处理Vue异常的方法
查看>>
漫谈前端性能,突破React应用瓶颈
查看>>
如何衡量一个人的 JavaScript 水平?
查看>>
北大计算机系女神每天必看必学的IT公众号
查看>>
JavaScript中数组的栈方法
查看>>
使用HTML5和CSS3制作遮罩文字特效
查看>>
CSS变量使用教程
查看>>
月入5W的程序员都关注了哪些公众号?
查看>>
【源码案例】14个超炫酷 HTML5/CSS3应用和动画特效实例
查看>>
18个基于 HTML5 Canvas 开发的图表库
查看>>
彻底终结 Javascript 背后的隐式类型转换
查看>>
14款CSS3炫酷表单input输入框美化效果【附源码】
查看>>
SVG系列教程01绘制SVG矩形
查看>>
跨浏览器纯JavaScript QRCode二维码插件【附DEMO源码】
查看>>
基于Threejs可着色和旋转的3D模型动画特效,附学习源码
查看>>
15种漂亮的css3 loading动画特效【源码案例】
查看>>
从原型图到成品:步步深入 CSS 布局
查看>>