2017-01-12 12:30:38 s3590024 阅读数 4309

目前市场点对点互联 成为热点,通常点对点连接用 蓝牙和wifi 两种方式。

1、蓝牙
传输速率低,失真率高。不适合传输大数据 如视频,图片等。
2、wifi
传输速率高,失真率低,即可作为热点ap,也可作为 终端wifi direct。适合视频和图片的传输等大数据传输。

加入一个APP 的需求既要通过wifi与只能硬件相连,又要通过APP中转把相关数据提交给后天服务器。
如心电设备 原理工作图如下 :

众所周知,手机同时打开WiFi和3G时候,会优先走WiFi。这个该如何实现呢?市面上有一个极路客APP已经实现此方案,网上各种搜索资料,出现一个Multipath TCP概念,但是这个系统没有API,瞬间抓狂,直接查看极路客APP与他们硬件连接的WIFI,发现与我们平时WiFi不一样,DNS没有。



经过各种测试,最后发现不填路由IP和DNS,填写IP和子网掩码就可以实现WiFi LAN通信,同时3G/4G WAN通信,所以只需要硬件那边做下配置就OK,最后发现苹果官网资料也显示不需要路由IP,有可能这就是所谓的multipath tcp技术,集成在系统内核里,系统自动根据这判断选择哪个网络通道。

2015-06-12 14:44:59 yangkunlll 阅读数 330

typedef enum {

    NETWORK_TYPE_NONE= 0,

    NETWORK_TYPE_WIFI= 1,

    NETWORK_TYPE_3G= 2,

    NETWORK_TYPE_2G= 3,

    NETWORK_TYPE_4G= 4,

}NETWORK_TYPE;


+ (int)dataNetworkTypeFromStatusBar {

     UIApplication *app = [UIApplication sharedApplication];

    NSArray *subviews = [[[app valueForKey:@"statusBar"] valueForKey:@"foregroundView"] subviews];

    NSNumber *dataNetworkItemView = nil;

    for (id subview in subviews) {

        if([subview isKindOfClass:[NSClassFromString(@"UIStatusBarDataNetworkItemView") class]]) {

            dataNetworkItemView = subview;

            break;

        }

    }

    int netType = NETWORK_TYPE_NONE;

    NSNumber * num = [dataNetworkItemView valueForKey:@"dataNetworkType"];

    if (num == nil) {

        netType = NETWORK_TYPE_NONE;

    }else{

        int n = [num intValue];

        if (n == 0) {

            netType = NETWORK_TYPE_NONE;

        }else if (n == 1){

            netType = NETWORK_TYPE_2G;

        }else if (n == 2){

            netType = NETWORK_TYPE_3G;

        }else if (n == 3){

            netType = NETWORK_TYPE_4G;

        }else{

            netType = NETWORK_TYPE_WIFI;

        }

    }

    return netType;

}


2016-05-29 16:45:54 feng2qing 阅读数 4956

4G网络和Wifi虽然已经基本普及,但是在实际开发中,任然需要针对不同的网络环境给出回应,比如Wifi环境下要自动缓存视频,2G环境下可能只需要加载缩略图等等,开发者如何打开这些环境是接下来要说的

打开Xcode—> Open Developer Tools—>More Developer Tools

这里写图片描述

点击之后会跳转苹果开发者中心,并且登录,我们找到Hardware IO Tools for Xcode7,进行下载

没有开发者账号的点击:https://github.com/1170197998/Hardware_IO_Tools_for_Xcode_7

这里写图片描述

下载后得到安装包:

这里写图片描述

双击安装,需要输入电脑的登录密码,安装之后显示如下:

这里写图片描述

双击 Network Line Conditioner.prePane,会弹出系统偏好设置,并且多了这个:

这里写图片描述

双击它,弹出如下界面

这里写图片描述

在Profile里面选择网络环境

这里写图片描述

解释:

100% Loss: 断网

3G:3Gwang

DSL:Digital Subscriber Line,数字用户线路

Edge:Enhanced Data Rate for GSM Evolution,增强型数据速率GSM演进技术,是一种从GSM到3G的过渡技术

High Latency DNS:高延迟的DNS

Very Bad Network:很菜的网络

Wifi:wifi网络

注:模拟器的网络环境会随着设置的变化而变化,根本上是改变了电脑本身的网络环境


同样真机测试的时候也可以设置不同网络环境,打开设置,找到开发者选项:

这里写图片描述

找到Status

这里写图片描述

显示的列表和刚才是一样的

这里写图片描述

2016-07-13 17:30:52 u011619283 阅读数 10297

5G 什么的,还得等苹果API更新啊,不过将来还是这个处理过程就是了。
关于判断当前的网络环境是2G/3G/4G,这个问题以前经常看到,最近在一工程里看到了如果判断的API。而在撸WebRTC音视频通话的时候,看到了Demo中将SCNetworkReachability与其结合,当网络环境改变时,判断当前连接的是什么网络环境,写法欠佳(因为将其与WebRTC的其他逻辑柔和在了一个类)。其实只需要将官方的Reachability做一下改进即可。

如何判断当前的网络环境

我们可以利用#import <CoreTelephony/CTTelephonyNetworkInfo.h>框架下的一些API来判断当前的网络。
先来看一下该框架下的一些常量定义:

CORETELEPHONY_EXTERN NSString * const CTRadioAccessTechnologyGPRS          __OSX_AVAILABLE_STARTING(__MAC_NA,__IPHONE_7_0);
CORETELEPHONY_EXTERN NSString * const CTRadioAccessTechnologyEdge          __OSX_AVAILABLE_STARTING(__MAC_NA,__IPHONE_7_0);
CORETELEPHONY_EXTERN NSString * const CTRadioAccessTechnologyWCDMA         __OSX_AVAILABLE_STARTING(__MAC_NA,__IPHONE_7_0);
CORETELEPHONY_EXTERN NSString * const CTRadioAccessTechnologyHSDPA         __OSX_AVAILABLE_STARTING(__MAC_NA,__IPHONE_7_0);
CORETELEPHONY_EXTERN NSString * const CTRadioAccessTechnologyHSUPA         __OSX_AVAILABLE_STARTING(__MAC_NA,__IPHONE_7_0);
CORETELEPHONY_EXTERN NSString * const CTRadioAccessTechnologyCDMA1x        __OSX_AVAILABLE_STARTING(__MAC_NA,__IPHONE_7_0);
CORETELEPHONY_EXTERN NSString * const CTRadioAccessTechnologyCDMAEVDORev0  __OSX_AVAILABLE_STARTING(__MAC_NA,__IPHONE_7_0);
CORETELEPHONY_EXTERN NSString * const CTRadioAccessTechnologyCDMAEVDORevA  __OSX_AVAILABLE_STARTING(__MAC_NA,__IPHONE_7_0);
CORETELEPHONY_EXTERN NSString * const CTRadioAccessTechnologyCDMAEVDORevB  __OSX_AVAILABLE_STARTING(__MAC_NA,__IPHONE_7_0);
CORETELEPHONY_EXTERN NSString * const CTRadioAccessTechnologyeHRPD         __OSX_AVAILABLE_STARTING(__MAC_NA,__IPHONE_7_0);
CORETELEPHONY_EXTERN NSString * const CTRadioAccessTechnologyLTE           __OSX_AVAILABLE_STARTING(__MAC_NA,__IPHONE_7_0);

这不就是2G/3G/4G等网络环境么?我想等5G普及之后,苹果肯定也会加入代表5G的常量定义的。
先看随手写的一个网络环境判断:

- (void)networkStatus
{
    NSArray *typeStrings2G = @[CTRadioAccessTechnologyEdge,
                               CTRadioAccessTechnologyGPRS,
                               CTRadioAccessTechnologyCDMA1x];
    
    NSArray *typeStrings3G = @[CTRadioAccessTechnologyHSDPA,
                               CTRadioAccessTechnologyWCDMA,
                               CTRadioAccessTechnologyHSUPA,
                               CTRadioAccessTechnologyCDMAEVDORev0,
                               CTRadioAccessTechnologyCDMAEVDORevA,
                               CTRadioAccessTechnologyCDMAEVDORevB,
                               CTRadioAccessTechnologyeHRPD];
    
    NSArray *typeStrings4G = @[CTRadioAccessTechnologyLTE];
    
    if ([[[UIDevice currentDevice] systemVersion] floatValue] >= 7.0) {
        CTTelephonyNetworkInfo *teleInfo= [[CTTelephonyNetworkInfo alloc] init];
        NSString *accessString = teleInfo.currentRadioAccessTechnology;
        if ([typeStrings4G containsObject:accessString]) {
            NSLog(@"4G网络");
        } else if ([typeStrings3G containsObject:accessString]) {
            NSLog(@"3G网络");
        } else if ([typeStrings2G containsObject:accessString]) {
            NSLog(@"2G网络");
        } else {
            NSLog(@"未知网络");
        }
    } else {
        NSLog(@"未知网络");
    }
}

代码中的currentRadioAccessTechnology是iOS 7之后新加的API。

改进Reachability

在iOS应用中的使用场景肯定不是主动获取,应该是网络产生变化的时候,自动给出通知等,然后做一些相应的处理。下面我们就自己撸一个Reachability,然后给出当前的网络环境。
我们都知道,使用Reachability时,如果网络变化,会给出一个通知,但是我们获取的网络状态只有WiFi/WWAN/NotReach几种。我们可以在Reachability返回的通知里,WWAN这种类型下,再做上面的网络判断即可。但是更优的做法就将判断放在Reachability中,在使用的时候直接返回不同的网络状态。
由于最新的Reachability已经支持了IPV6,我也是在最新的Reachability上做了一些改进。
大部分方法跟Reachability一样,我扩展了枚举类型,修改了网络状态判断。
主要修改如下:

typedef NS_ENUM(NSUInteger, HLNetWorkStatus) {
    HLNetWorkStatusNotReachable = 0,
    HLNetWorkStatusUnknown = 1,
    HLNetWorkStatusWWAN2G = 2,
    HLNetWorkStatusWWAN3G = 3,
    HLNetWorkStatusWWAN4G = 4,
    
    HLNetWorkStatusWiFi = 9,
};

这里是网络类型判断的修改:

- (HLNetWorkStatus)networkStatusForFlags:(SCNetworkReachabilityFlags)flags
{
    if ((flags & kSCNetworkReachabilityFlagsReachable) == 0)
    {
        // The target host is not reachable.
        return HLNetWorkStatusNotReachable;
    }
    
    HLNetWorkStatus returnValue = HLNetWorkStatusNotReachable;
    if ((flags & kSCNetworkReachabilityFlagsConnectionRequired) == 0)
    {
        /*
         If the target host is reachable and no connection is required then we'll assume (for now) that you're on Wi-Fi...
         */
        returnValue = HLNetWorkStatusWiFi;
    }
    
    if ((((flags & kSCNetworkReachabilityFlagsConnectionOnDemand ) != 0) ||
         (flags & kSCNetworkReachabilityFlagsConnectionOnTraffic) != 0))
    {
        /*
         ... and the connection is on-demand (or on-traffic) if the calling application is using the CFSocketStream or higher APIs...
         */
        
        if ((flags & kSCNetworkReachabilityFlagsInterventionRequired) == 0)
        {
            /*
             ... and no [user] intervention is needed...
             */
            returnValue = HLNetWorkStatusWiFi;
        }
    }
    
    if ((flags & kSCNetworkReachabilityFlagsIsWWAN) == kSCNetworkReachabilityFlagsIsWWAN)
    {
        /*
         ... but WWAN connections are OK if the calling application is using the CFNetwork APIs.
         */
        NSArray *typeStrings2G = @[CTRadioAccessTechnologyEdge,
                           CTRadioAccessTechnologyGPRS,
                           CTRadioAccessTechnologyCDMA1x];
        
        NSArray *typeStrings3G = @[CTRadioAccessTechnologyHSDPA,
                           CTRadioAccessTechnologyWCDMA,
                           CTRadioAccessTechnologyHSUPA,
                           CTRadioAccessTechnologyCDMAEVDORev0,
                           CTRadioAccessTechnologyCDMAEVDORevA,
                           CTRadioAccessTechnologyCDMAEVDORevB,
                           CTRadioAccessTechnologyeHRPD];
        
        NSArray *typeStrings4G = @[CTRadioAccessTechnologyLTE];

        if ([[[UIDevice currentDevice] systemVersion] floatValue] >= 7.0) {
            CTTelephonyNetworkInfo *teleInfo= [[CTTelephonyNetworkInfo alloc] init];
            NSString *accessString = teleInfo.currentRadioAccessTechnology;
            if ([typeStrings4G containsObject:accessString]) {
                return HLNetWorkStatusWWAN4G;
            } else if ([typeStrings3G containsObject:accessString]) {
                return HLNetWorkStatusWWAN3G;
            } else if ([typeStrings2G containsObject:accessString]) {
                return HLNetWorkStatusWWAN2G;
            } else {
                return HLNetWorkStatusUnknown;
            }
        } else {
            return HLNetWorkStatusUnknown;
        }
    }

    return returnValue;
}

改进后的Reachability用法

为了便于使用,尽量按照Reachability的做法来处理,所以用法与之前没什么太大区别,就换了个通知而已。

    [[NSNotificationCenter defaultCenter] addObserver:self selector:@selector(reachabilityChanged:) name:kNetWorkReachabilityChangedNotification object:nil];
    
    HLNetWorkReachability *reachability = [HLNetWorkReachability reachabilityWithHostName:@"www.baidu.com"];
    self.hostReachability = reachability;
    [reachability startNotifier];

// 通知处理
- (void)reachabilityChanged:(NSNotification *)notification
{
    HLNetWorkReachability *curReach = [notification object];
    HLNetWorkStatus netStatus = [curReach currentReachabilityStatus];
    switch (netStatus) {
        case HLNetWorkStatusNotReachable:
            NSLog(@"网络不可用");
            break;
        case HLNetWorkStatusUnknown:
            NSLog(@"未知网络");
            break;
        case HLNetWorkStatusWWAN2G:
            NSLog(@"2G网络");
            break;
        case HLNetWorkStatusWWAN3G:
            NSLog(@"3G网络");
            break;
        case HLNetWorkStatusWWAN4G:
            NSLog(@"4G网络");
            break;
        case HLNetWorkStatusWiFi:
            NSLog(@"WiFi");
            break;
            
        default:
            break;
    }
}

完整Demo地址:HLNetWorkReachability
Have Fun!

2019-05-04 23:07:58 ysysbaobei 阅读数 4036

       iOS12加密相册、保险箱、加密相册Pro、保险箱Pro打开就闪退的,去iPhone/iPad桌面找到"设置",点击设置后下滑出现搜索栏,搜索闪退的app名字(比如加密相册),找到无线数据(如果没有此项,只有4g蜂窝移动数据,请在设备底部上滑,然后关闭4g蜂窝网络和WiFi的开关),点进去选择第一行“关闭”,就可以正常使用闪退的app了。下图为操作步骤:

       加密相册、保险箱、加密相册Pro、保险箱Pro被苹果下架了,建议进入app后,点击右下角设置按钮,找到备份本App所有数据(换手机必看):同时采用方法一和方法二备份数据;方法二备份到电脑某个硬盘,一定要能在电脑里找到你备份的照片和视频才算备份成功。

      请下载新加密相册:https://itunes.apple.com/app/id1458351572?mt=8,如何转移老加密相册数据到新app?在数据完全转移成功前,不要删除老加密相册,因为删除会丢失数据。登录老加密相册后,点击右下角设置,找到备份本app所有数据,滑动到底部,点击“备份所有数据到电脑(方法二)”,将老加密相册数据通过电脑iTunes备份到电脑硬盘,再通过电脑iTunes导入备份数据到新app中。有任何问题加技术支持qq群:961952432

没有更多推荐了,返回首页