Как проверить активное интернет-соединение на iOS или macOS?

Я хотел бы проверить, есть ли у меня подключение к Интернету на iOS с использованием библиотек Cocoa Touch или на macOS с использованием библиотек Cocoa .

Я придумал способ сделать это, используя NSURL. То, как я это сделал, кажется немного ненадежным (потому что даже Google может однажды оказаться неработоспособным, а полагаться на третье лицо кажется плохим), и хотя я мог проверить, есть ли ответ от других веб-сайтов, если Google не отвечает, это действительно кажется расточительным и ненужными накладными расходами на мое приложение.

- (BOOL) connectedToInternet
{
    NSString *URLString = [NSString stringWithContentsOfURL:[NSURL URLWithString:@"http://www.google.com"]];
    return ( URLString != NULL ) ? YES : NO;
}

Это то, что я сделал плохо (не говоря stringWithContentsOfURLуже об устаревшем в iOS 3.0 и macOS 10.4), и если так, какой лучший способ сделать это?

5.07.2009 08:45:01
Скорее return (BOOL)URLString;или даже лучше, return !!URLStringилиreturn URLString != nil
user529758 24.06.2012 20:48:46
Я не знаю, каков ваш вариант использования, но если вы можете, лучше попробовать запрос и обработать любые ошибки, такие как отсутствие соединения, которое возникает. Если вы не можете этого сделать, то в этом случае есть много полезных советов.
SK9 1.07.2013 05:06:59
Ваше решение умное, и я предпочитаю это. Вы также можете использовать, NSString *URLString = [NSString stringWithContentsOfURL:[NSURL URLWithString:@"https://twitter.com/getibox"] encoding:NSUTF8StringEncoding error:nil];чтобы избавиться от надоедливого предупреждения.
Abdelrahman Eid 29.10.2013 16:56:18
попробуйте использовать класс Reachability из ссылки ниже, он будет работать для вас github.com/tonymillion/Reachability
Dhaval H. Nena 1.01.2014 12:11:07
Для тех, кто недавно нашел этот ответ: stackoverflow.com/a/8813279
afollestad 17.04.2014 20:16:56
30 ОТВЕТОВ
РЕШЕНИЕ

Важно : эта проверка всегда должна выполняться асинхронно. Большинство ответов ниже являются синхронными, поэтому будьте осторожны, иначе вы заморозите свое приложение.


стриж

1) Установите через CocoaPods или Карфаген: https://github.com/ashleymills/Reachability.swift

2) Тест достижимости через замыкания

let reachability = Reachability()!

reachability.whenReachable = { reachability in
    if reachability.connection == .wifi {
        print("Reachable via WiFi")
    } else {
        print("Reachable via Cellular")
    }
}

reachability.whenUnreachable = { _ in
    print("Not reachable")
}

do {
    try reachability.startNotifier()
} catch {
    print("Unable to start notifier")
}

Objective-C

1) Добавьте SystemConfigurationфреймворк в проект, но не беспокойтесь о его включении

2) Добавить версию Tony Million Reachability.hи Reachability.mв проект (можно найти здесь: https://github.com/tonymillion/Reachability )

3) Обновление раздела интерфейса

#import "Reachability.h"

// Add this to the interface in the .m file of your view controller
@interface MyViewController ()
{
    Reachability *internetReachableFoo;
}
@end

4) Затем внедрите этот метод в файл .m вашего контроллера представления, который вы можете вызвать

// Checks if we have an internet connection or not
- (void)testInternetConnection
{   
    internetReachableFoo = [Reachability reachabilityWithHostname:@"www.google.com"];

    // Internet is reachable
    internetReachableFoo.reachableBlock = ^(Reachability*reach)
    {
        // Update the UI on the main thread
        dispatch_async(dispatch_get_main_queue(), ^{
            NSLog(@"Yayyy, we have the interwebs!");
        });
    };

    // Internet is not reachable
    internetReachableFoo.unreachableBlock = ^(Reachability*reach)
    {
        // Update the UI on the main thread
        dispatch_async(dispatch_get_main_queue(), ^{
            NSLog(@"Someone broke the internet :(");
        });
    };

    [internetReachableFoo startNotifier];
}

Важное примечание:Reachability класс является одним из наиболее часто используемых классов в проектах , так что вы можете столкнуться конфликты имен с другими проектами. Если это произойдет, вам придется переименовать одну из пар Reachability.hи Reachability.mфайлов во что-то другое, чтобы решить проблему.

Примечание: домен, который вы используете, не имеет значения. Это просто тестирование шлюза в любой домен.

1284
17.04.2018 12:45:24
@gonzobrains: домен, который вы используете, не имеет значения. Это просто тестирование шлюза в любой домен.
iwasrobbed 14.06.2011 21:33:09
@KaanDedeoglu Это всего лишь пример, используйте любой домен, который вы хотите. Он просто проверяет наличие шлюза в Интернет, а не то, что домен действительно доступен.
iwasrobbed 6.05.2013 16:04:47
О, кстати, вам нужно добавить SystemConfiguration.frameworkв проект (для метода 1).
wiseindy 16.08.2013 18:55:52
Используйте www.appleiphonecell.com вместо google.com - этот URL был создан Apple именно по этой причине.
Smikey 25.07.2015 13:55:32
Использование www.appleiphonecell.com в настоящее время (2018) является плохим выбором. Теперь он перенаправляет на Apple.com, который является> 40 КБ HTML-файл. Вернуться на google.com - это всего 11kB. Кстати, google.com/m имеет тот же размер, но, как сообщается, медленнее на 120 мсек.
BlueskyMed 9.12.2018 17:31:21

Apple предоставляет пример приложения, которое делает именно это:

достижимость

39
11.06.2013 10:04:05
Следует отметить, что образец Reachability обнаруживает только то, какие интерфейсы активны, но не какие из них имеют действительное подключение к Интернету. Приложения должны корректно обрабатывать ошибки, даже когда Reachability сообщает, что все готово к работе.
rpetrich 5.07.2009 11:17:27
К счастью, в 3.0 ситуация намного лучше, так как система представит страницу входа для пользователей за заблокированным WiFi, где вы должны войти в систему, чтобы использовать ... вы используете для проверки перенаправления вручную (и вы все равно делаете если разрабатывает приложения 2.2.1)
Kendall Helmstetter Gelner 6.07.2009 04:28:11
Я бы не сказал, что приложение Reachability делает именно то, что требуется. Однако это хорошая отправная точка для добавления
Johan Karlsson 9.01.2019 13:46:13

Apple предоставляет пример кода для проверки доступности различных типов сети. В качестве альтернативы есть пример в поваренной книге разработчиков iPhone.

Примечание. См. Комментарий @ KHG к этому ответу относительно использования кода доступности Apple.

57
28.01.2011 07:04:57
Спасибо. Я обнаружил, что документация XCode в 3.0 также содержит исходный код, найденный поиском «достижимости» в документации.
Brock Woolf 5.07.2009 11:37:02
Обратите внимание, что новая редакция (09-08-09) образца кода Reachability от Apple является асинхронной.
Daniel Hepper 17.01.2010 21:03:49

Я использовал код в этом обсуждении , и он, кажется, работает нормально (прочитайте всю ветку!).

Я не проверял это исчерпывающе с каждым мыслимым типом соединения (например, Wi-Fi ad hoc).

18
9.01.2016 12:37:33
этот код не совсем хорош, потому что он просто проверяет, есть ли у вас Wi-Fi-соединение с маршрутизатором, а не доступ к сети. Вы можете включить Wi-Fi и продолжить доступ к сети.
SpaceDog 21.11.2009 02:43:46

Раньше это был правильный ответ, но теперь он устарел, так как вместо этого вы должны подписаться на уведомления о доступности. Этот метод проверяет синхронно:


Вы можете использовать класс доступности Apple. Это также позволит вам проверить, включен ли Wi-Fi:

Reachability* reachability = [Reachability sharedReachability];
[reachability setHostName:@"www.example.com"];    // Set your host name here
NetworkStatus remoteHostStatus = [reachability remoteHostStatus];

if (remoteHostStatus == NotReachable) { }
else if (remoteHostStatus == ReachableViaWiFiNetwork) { }
else if (remoteHostStatus == ReachableViaCarrierDataNetwork) { }

Класс Reachability поставляется не с SDK, а является частью этого образца приложения Apple . Просто скачайте его и скопируйте Reachability.h / m в ваш проект. Кроме того, вы должны добавить инфраструктуру SystemConfiguration в ваш проект.

121
9.01.2016 12:40:49
Смотрите мой комментарий выше о том, чтобы не использовать Reachability как этот. Используйте его в асинхронном режиме и подписывайтесь на уведомления, которые он отправляет - не делайте.
Kendall Helmstetter Gelner 6.07.2009 04:29:22
Этот код является хорошей отправной точкой для вещей, которые вам нужно установить, прежде чем вы сможете использовать методы делегата для класса достижимости.
Brock Woolf 6.07.2009 13:42:34

Только класс Reachability был обновлен. Теперь вы можете использовать:

Reachability* reachability = [Reachability reachabilityWithHostName:@"www.apple.com"];
NetworkStatus remoteHostStatus = [reachability currentReachabilityStatus];

if (remoteHostStatus == NotReachable) { NSLog(@"not reachable");}
else if (remoteHostStatus == ReachableViaWWAN) { NSLog(@"reachable via wwan");}
else if (remoteHostStatus == ReachableViaWiFi) { NSLog(@"reachable via wifi");}
33
9.01.2016 12:41:52
Если с момента выпуска 4.0 что-то не изменилось, этот код не является асинхронным, и вы гарантированно увидите его в отчетах о сбоях - это случилось со мной раньше.
bpapa 27.08.2010 15:10:21
Я согласен с бпапа. Это не очень хорошая идея использовать синхронный код. Спасибо за информацию, хотя
Brock Woolf 27.08.2010 18:28:19

Мне нравится, чтобы все было просто. Я делаю это так:

//Class.h
#import "Reachability.h"
#import <SystemConfiguration/SystemConfiguration.h>

- (BOOL)connected;

//Class.m
- (BOOL)connected
{
    Reachability *reachability = [Reachability reachabilityForInternetConnection];
    NetworkStatus networkStatus = [reachability currentReachabilityStatus];
    return networkStatus != NotReachable;
}

Затем я использую это всякий раз, когда я хочу увидеть, есть ли у меня соединение:

if (![self connected]) {
    // Not connected
} else {
    // Connected. Do some Internet stuff
}

Этот метод не ждет изменения состояния сети, чтобы что-то делать. Он просто проверяет состояние, когда вы его просите.

310
9.01.2016 12:42:52
Здравствуйте, @msec, вы можете попробовать решение Эндрю Циммера на этой странице, оно отлично работает с отключенным adsl (и подключенным wifi)
Williew 5.05.2012 02:30:32
Для тех, кто просто копирует и вставляет, как я сделал с приведенным выше кодом. Также добавьте SystemConfiguration.framework вручную, иначе вы получите ошибку компоновки.
Iftikhar Ali Ansari 14.01.2015 13:56:59
Всегда будь доступным, если я соединяюсь с WiFi. WiFi не означает, что у него есть подключение к интернету. Я хочу проверить подключение к интернету, даже если у него есть подключение к WiFi. Можете ли вы помочь мне?
wesley 29.01.2019 11:55:48
@wesley Как ты решил это?
Keselme 8.01.2020 15:19:24

Используя код Reachability от Apple, я создал функцию, которая будет проверять это правильно, без необходимости включать какие-либо классы.

Включите SystemConfiguration.framework в ваш проект.

Сделайте некоторые импортные:

#import <sys/socket.h>
#import <netinet/in.h>
#import <SystemConfiguration/SystemConfiguration.h>

Теперь просто вызовите эту функцию:

/*
Connectivity testing code pulled from Apple's Reachability Example: https://developer.apple.com/library/content/samplecode/Reachability
 */
+(BOOL)hasConnectivity {
    struct sockaddr_in zeroAddress;
    bzero(&zeroAddress, sizeof(zeroAddress));
    zeroAddress.sin_len = sizeof(zeroAddress);
    zeroAddress.sin_family = AF_INET;

    SCNetworkReachabilityRef reachability = SCNetworkReachabilityCreateWithAddress(kCFAllocatorDefault, (const struct sockaddr*)&zeroAddress);
    if (reachability != NULL) {
        //NetworkStatus retVal = NotReachable;
        SCNetworkReachabilityFlags flags;
        if (SCNetworkReachabilityGetFlags(reachability, &flags)) {
            if ((flags & kSCNetworkReachabilityFlagsReachable) == 0)
            {
                // If target host is not reachable
                return NO;
            }

            if ((flags & kSCNetworkReachabilityFlagsConnectionRequired) == 0)
            {
                // If target host is reachable and no connection is required
                //  then we'll assume (for now) that your on Wi-Fi
                return YES;
            }


            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
                    return YES;
                }
            }

            if ((flags & kSCNetworkReachabilityFlagsIsWWAN) == kSCNetworkReachabilityFlagsIsWWAN)
            {
                // ... but WWAN connections are OK if the calling application
                //     is using the CFNetwork (CFSocketStream?) APIs.
                return YES;
            }
        }
    }

    return NO;
}

И это iOS 5 проверено для вас.

145
2.07.2017 16:34:56
@JezenThomas Это не выполняет интернет-проверку асинхронно, поэтому она «намного тоньше» ... Вы всегда должны делать это асинхронно, подписываясь на уведомления, чтобы не повесить приложение в этом процессе.
iwasrobbed 3.05.2012 05:29:58
Спасибо, эта работа, даже если вы используете Wi-Fi ADSL и ADSL не подключен, это именно то, что мне нужно.
Williew 5.05.2012 02:27:24
Это приводит к утечке памяти - структура «читабельность» (объект, вещь) должна быть освобождена с помощью CFRelease ().
Russell Mull 20.11.2012 08:52:42
@RussellMull ... есть идеи, как исправить утечку?
i_raqz 15.09.2013 05:23:51
Странно, что этот ответ предшествует моему (на вопрос, помеченный как дубликат) на 2 года, точно так же, как мой, но я никогда не видел его до сегодняшнего дня.
ArtOfWarfare 30.01.2014 05:32:41

Версия на Reachability для iOS 5 - это darkseed / Reachability.h . Это не мое! знак равно

27
9.01.2016 12:46:23

Здесь есть привлекательная модернизация Reachability с использованием ARC и GCD:

достижимость

25
11.06.2013 10:04:51

Вы можете использовать Reachability ( доступно здесь ).

#import "Reachability.h"

- (BOOL)networkConnection {
    return [[Reachability reachabilityWithHostName:@"www.google.com"] currentReachabilityStatus];
}

if ([self networkConnection] == NotReachable) { /* No Network */ } else { /* Network */ } //Use ReachableViaWiFi / ReachableViaWWAN to get the type of connection.
46
26.08.2017 02:46:57
@Supertecnoboff Нет, это асинхронно.
Aleksander Azizi 8.11.2018 19:10:33

Вот очень простой ответ:

NSURL *scriptUrl = [NSURL URLWithString:@"http://www.google.com/m"];
NSData *data = [NSData dataWithContentsOfURL:scriptUrl];
if (data)
    NSLog(@"Device is connected to the Internet");
else
    NSLog(@"Device is not connected to the Internet");

URL должен указывать на очень маленький сайт. Я использую мобильный сайт Google здесь, но если бы у меня был надежный веб-сервер, я бы загрузил небольшой файл с одним символом для максимальной скорости.

Если проверки , является ли устройство каким - то образом подключено к Интернету все , что вы хотите сделать, я бы определенно рекомендую использовать это простое решение. Если вам нужно знать, как пользователь подключен, используйте Reachability.

Осторожно: это ненадолго заблокирует вашу ветку, пока он загружает сайт. В моем случае это не было проблемой, но вы должны рассмотреть это (благодарность Брэду за указание на это).

82
9.01.2016 12:50:43
Мне очень нравится эта идея, но я бы сказал, что для надежности 99,999% при сохранении небольшого размера ответа перейдите на страницу www.google.com/m, которая является мобильным представлением для Google.
rwyland 23.09.2012 05:46:37
Отличное решение @Erik. Я также рекомендую вам использовать www.google.com вместо www.google.com/m, как сказал rwyland. Это странно, но из моего теста мобильная версия всегда занимает примерно на 120 мс больше, чем www.google.com
Sebyddd 15.05.2014 13:27:02
Документы Apple рекомендуют не делать этого, так как это может блокировать поток в медленной сети, может привести к прекращению работы приложения в iOS
Brad Thomas 7.10.2014 17:44:18
Спасибо за положительный отзыв, согласитесь, что www.google.com/m является лучшим решением из-за надежности!
Erik 8.08.2015 13:02:33
LOL, я уверен, что Google ценит, что вы предлагаете людям использовать их в качестве ресурса для проверки интернета.
mxcl 3.04.2018 15:28:03
- (void)viewWillAppear:(BOOL)animated
{
    NSString *URL = [NSString stringWithContentsOfURL:[NSURL URLWithString:@"http://www.google.com"]];

    return (URL != NULL ) ? YES : NO;
}

Или используйте класс Reachability .

Есть два способа проверить доступность Интернета с помощью iPhone SDK:

1. Проверьте, открыта страница Google или нет.

2. Класс достижимости

Для получения дополнительной информации, пожалуйста, обратитесь к Reachability (Apple Developer).

11
9.01.2016 12:52:04
Есть два способа проверить доступность интернета в iPhone SDK 1) Проверьте, открыта страница Google или нет.
IOS Rocks 22.11.2012 12:04:50
-1: это синхронный метод, который блокирует основной поток (тот, на котором изменен пользовательский интерфейс приложения), когда он пытается подключиться к google.com. Если у вашего пользователя очень медленное соединение для передачи данных, телефон будет действовать так, как будто процесс не отвечает.
iwasrobbed 25.03.2013 23:05:10

Вот как я делаю это в своих приложениях: хотя код ответа 200 и ничего не гарантирует, он достаточно стабилен для меня. Это не требует такой большой загрузки, как ответы NSData, опубликованные здесь, так как мой просто проверяет ответ HEAD.

Swift Code

func checkInternet(flag:Bool, completionHandler:(internet:Bool) -> Void)
{
    UIApplication.sharedApplication().networkActivityIndicatorVisible = true

    let url = NSURL(string: "http://www.google.com/")
    let request = NSMutableURLRequest(URL: url!)

    request.HTTPMethod = "HEAD"
    request.cachePolicy = NSURLRequestCachePolicy.ReloadIgnoringLocalAndRemoteCacheData
    request.timeoutInterval = 10.0

    NSURLConnection.sendAsynchronousRequest(request, queue:NSOperationQueue.mainQueue(), completionHandler:
    {(response: NSURLResponse!, data: NSData!, error: NSError!) -> Void in

        UIApplication.sharedApplication().networkActivityIndicatorVisible = false

        let rsp = response as! NSHTTPURLResponse?

        completionHandler(internet:rsp?.statusCode == 200)
    })
}

func yourMethod()
{
    self.checkInternet(false, completionHandler:
    {(internet:Bool) -> Void in

        if (internet)
        {
            // "Internet" aka Google URL reachable
        }
        else
        {
            // No "Internet" aka Google URL un-reachable
        }
    })
}

Код Objective-C

typedef void(^connection)(BOOL);

- (void)checkInternet:(connection)block
{
    NSURL *url = [NSURL URLWithString:@"http://www.google.com/"];
    NSMutableURLRequest *headRequest = [NSMutableURLRequest requestWithURL:url];
    headRequest.HTTPMethod = @"HEAD";

    NSURLSessionConfiguration *defaultConfigObject = [NSURLSessionConfiguration ephemeralSessionConfiguration];
    defaultConfigObject.timeoutIntervalForResource = 10.0;
    defaultConfigObject.requestCachePolicy = NSURLRequestReloadIgnoringLocalAndRemoteCacheData;

    NSURLSession *defaultSession = [NSURLSession sessionWithConfiguration:defaultConfigObject delegate:self delegateQueue: [NSOperationQueue mainQueue]];

    NSURLSessionDataTask *dataTask = [defaultSession dataTaskWithRequest:headRequest
        completionHandler:^(NSData *data, NSURLResponse *response, NSError *error)
    {
        if (!error && response)
        {
            block([(NSHTTPURLResponse *)response statusCode] == 200);
        }
    }];
    [dataTask resume];
}

- (void)yourMethod
{
    [self checkInternet:^(BOOL internet)
    {
         if (internet)
         {
             // "Internet" aka Google URL reachable
         }
         else
         {
             // No "Internet" aka Google URL un-reachable
         }
    }];
}
73
7.01.2019 16:10:02
Похоже, это самый быстрый путь
Pavel 21.03.2013 08:28:17
Внимание: по моему опыту, это решение не работает все время. Во многих случаях ответ возвращается 403, после того, как он потратил сладкое время. Это решение казалось идеальным, но не гарантирует 100% результатов.
Mustafa 9.05.2013 07:54:34
По состоянию на июнь 2014 года это не получится в материковом Китае из-за того, что правительство Китая теперь полностью блокирует google.com. (google.cn работает, хотя, но в материковом Китае нет baidu.com, нет интернета) Вероятно, лучше пинговать любой сервер, с которым вам нужно общаться.
prewett 28.07.2014 05:28:57
Вместо этого используйте www.appleiphonecell.com - Apple создал этот URL именно по этой причине.
Smikey 25.07.2015 13:53:06
Я использовал appleiphonecell, так как он принадлежит Apple, его можно использовать и в Китае, и это очень быстрый сайт. Это, в сочетании с вашим ответом, дало мне самое ближайшее и быстрое решение. Спасибо
Septronic 9.11.2015 14:18:08

Если вы используете, AFNetworkingвы можете использовать его собственную реализацию для статуса доступности интернета.

Лучший способ использовать AFNetworkingэто создать подкласс AFHTTPClientкласса и использовать этот класс для сетевых подключений.

Одним из преимуществ использования этого подхода является то, что вы можете blocksустановить желаемое поведение при изменении состояния достижимости. Предположим, что я создал одноэлементный подкласс с AFHTTPClientименем (как сказано в «Примечаниях по подклассам» в документах AFNetworking ) BKHTTPClient, я бы сделал что-то вроде:

BKHTTPClient *httpClient = [BKHTTPClient sharedClient];
[httpClient setReachabilityStatusChangeBlock:^(AFNetworkReachabilityStatus status)
{
    if (status == AFNetworkReachabilityStatusNotReachable) 
    {
    // Not reachable
    }
    else
    {
        // Reachable
    }
}];

Можно также проверить соединения Wi-Fi или WLAN с помощью специально AFNetworkReachabilityStatusReachableViaWWANи AFNetworkReachabilityStatusReachableViaWiFiперечислений ( подробнее здесь ).

22
30.05.2013 01:18:13
-(void)newtworkType {

 NSArray *subviews = [[[[UIApplication sharedApplication] valueForKey:@"statusBar"] valueForKey:@"foregroundView"]subviews];
NSNumber *dataNetworkItemView = nil;

for (id subview in subviews) {
    if([subview isKindOfClass:[NSClassFromString(@"UIStatusBarDataNetworkItemView") class]]) {
        dataNetworkItemView = subview;
        break;
    }
}


switch ([[dataNetworkItemView valueForKey:@"dataNetworkType"]integerValue]) {
    case 0:
        NSLog(@"No wifi or cellular");
        break;

    case 1:
        NSLog(@"2G");
        break;

    case 2:
        NSLog(@"3G");
        break;

    case 3:
        NSLog(@"4G");
        break;

    case 4:
        NSLog(@"LTE");
        break;

    case 5:
        NSLog(@"Wifi");
        break;


    default:
        break;
}
}
12
3.06.2013 11:43:13
Даже если устройство подключено к Wi-Fi или сети другого типа, подключение к Интернету может быть недоступно. Простой тест: подключитесь к домашней сети Wi-Fi, а затем отключите кабельный модем. Все еще подключен к Wi-Fi, но без интернета.
iwasrobbed 22.08.2013 14:35:16

Сначала загрузите класс досягаемости и поместите файл reachability.h и reachabilty.m в свой Xcode .

Лучший способ - создать общий класс функций (NSObject), чтобы вы могли использовать его в любом классе. Это два метода проверки доступности сетевого подключения:

+(BOOL) reachabiltyCheck
{
    NSLog(@"reachabiltyCheck");
    BOOL status =YES;
    [[NSNotificationCenter defaultCenter] addObserver:self
                                          selector:@selector(reachabilityChanged:)
                                          name:kReachabilityChangedNotification
                                          object:nil];
    Reachability * reach = [Reachability reachabilityForInternetConnection];
    NSLog(@"status : %d",[reach currentReachabilityStatus]);
    if([reach currentReachabilityStatus]==0)
    {
        status = NO;
        NSLog(@"network not connected");
    }
    reach.reachableBlock = ^(Reachability * reachability)
    {
        dispatch_async(dispatch_get_main_queue(), ^{
        });
    };
    reach.unreachableBlock = ^(Reachability * reachability)
    {
        dispatch_async(dispatch_get_main_queue(), ^{
        });
    };
    [reach startNotifier];
    return status;
}

+(BOOL)reachabilityChanged:(NSNotification*)note
{
    BOOL status =YES;
    NSLog(@"reachabilityChanged");
    Reachability * reach = [note object];
    NetworkStatus netStatus = [reach currentReachabilityStatus];
    switch (netStatus)
    {
        case NotReachable:
            {
                status = NO;
                NSLog(@"Not Reachable");
            }
            break;

        default:
            {
                if (!isSyncingReportPulseFlag)
                {
                    status = YES;
                    isSyncingReportPulseFlag = TRUE;
                    [DatabaseHandler checkForFailedReportStatusAndReSync];
                }
            }
            break;
    }
    return status;
}

+ (BOOL) connectedToNetwork
{
    // Create zero addy
    struct sockaddr_in zeroAddress;
    bzero(&zeroAddress, sizeof(zeroAddress));
    zeroAddress.sin_len = sizeof(zeroAddress);
    zeroAddress.sin_family = AF_INET;

    // Recover reachability flags
    SCNetworkReachabilityRef defaultRouteReachability = SCNetworkReachabilityCreateWithAddress(NULL, (struct sockaddr *)&zeroAddress);
    SCNetworkReachabilityFlags flags;
    BOOL didRetrieveFlags = SCNetworkReachabilityGetFlags(defaultRouteReachability, &flags);
    CFRelease(defaultRouteReachability);
    if (!didRetrieveFlags)
    {
        NSLog(@"Error. Could not recover network reachability flags");
        return NO;
    }
    BOOL isReachable = flags & kSCNetworkFlagsReachable;
    BOOL needsConnection = flags & kSCNetworkFlagsConnectionRequired;
    BOOL nonWiFi = flags & kSCNetworkReachabilityFlagsTransientConnection;
    NSURL *testURL = [NSURL URLWithString:@"http://www.apple.com/"];
    NSURLRequest *testRequest = [NSURLRequest requestWithURL:testURL  cachePolicy:NSURLRequestReloadIgnoringLocalCacheData timeoutInterval:20.0];
    NSURLConnection *testConnection = [[NSURLConnection alloc] initWithRequest:testRequest delegate:self];
    return ((isReachable && !needsConnection) || nonWiFi) ? (testConnection ? YES : NO) : NO;
}

Теперь вы можете проверить сетевое соединение в любом классе, вызвав этот метод класса.

8
9.01.2016 12:58:03

Класс Reachability в порядке, чтобы узнать, доступно ли подключение к Интернету для устройства или нет ...

Но в случае доступа к ресурсу интрасети :

Проверка связи с сервером интрасети с помощью класса достижимости всегда возвращает значение true.

Таким образом, быстрым решением в этом сценарии было бы создание веб-метода, вызываемого pingmeвместе с другими веб-методами в службе. pingmeДолжен вернуть что - то.

Поэтому я написал следующий метод для общих функций

-(BOOL)PingServiceServer
{
    NSURL *url=[NSURL URLWithString:@"http://www.serveraddress/service.asmx/Ping"];

    NSMutableURLRequest *urlReq=[NSMutableURLRequest requestWithURL:url];

    [urlReq setTimeoutInterval:10];

    NSURLResponse *response;

    NSError *error = nil;

    NSData *receivedData = [NSURLConnection sendSynchronousRequest:urlReq
                                                 returningResponse:&response
                                                             error:&error];
    NSLog(@"receivedData:%@",receivedData);

    if (receivedData !=nil)
    {
        return YES;
    }
    else
    {
        NSLog(@"Data is null");
        return NO;
    }
}

Вышеописанный метод был очень полезен для меня, поэтому всякий раз, когда я пытаюсь отправить некоторые данные на сервер, я всегда проверяю достижимость моего ресурса интрасети, используя этот URLRequest с малым временем ожидания.

7
9.01.2016 13:00:05

Используйте http://huytd.github.io/datatify/ . Это проще, чем добавлять библиотеки и писать код самостоятельно.

10
9.01.2016 13:00:28

Получите класс Reachabilty по адресу https://github.com/tonymillion/Reachability , добавьте инфраструктуру конфигурации системы в свой проект, импортируйте Reachability.h в свой класс и реализуйте пользовательские методы, как показано ниже:

- (BOOL)isConnectedToInternet
{
    //return NO; // Force for offline testing
    Reachability *hostReach = [Reachability reachabilityForInternetConnection];
    NetworkStatus netStatus = [hostReach currentReachabilityStatus];
    return !(netStatus == NotReachable);
}
3
9.01.2016 13:01:45
-1; ничего не добавляет к этой теме, что принятый ответ уже не покрывает лучше, IMO. Кроме того, все ваше тело метода может быть просто заменено наreturn [[Reachability reachabilityForInternetConnection] isReachable];
Mark Amery 17.09.2013 11:37:17

Импортируйте Reachable.hкласс в свой ViewControllerи используйте следующий код для проверки подключения :

     #define hasInternetConnection [[Reachability reachabilityForInternetConnection] isReachable]
     if (hasInternetConnection){
           // To-do block
     }
6
9.01.2016 13:02:19
Ваш ответ именно то, что я ищу. Вы, сэр, заслуживаете голоса до xD
Nikel Arteta 6.02.2015 10:54:34
Не работает, если вы подключены к WiFi без интернета.
Keselme 12.01.2020 10:39:34

Существует также другой способ проверки интернет-соединения с помощью iPhone SDK.

Попробуйте реализовать следующий код для сетевого подключения.

#import <SystemConfiguration/SystemConfiguration.h>
#include <netdb.h>

/**
     Checking for network availability. It returns
     YES if the network is available.
*/
+ (BOOL) connectedToNetwork
{

    // Create zero addy
    struct sockaddr_in zeroAddress;
    bzero(&zeroAddress, sizeof(zeroAddress));
    zeroAddress.sin_len = sizeof(zeroAddress);
    zeroAddress.sin_family = AF_INET;

    // Recover reachability flags
    SCNetworkReachabilityRef defaultRouteReachability =
        SCNetworkReachabilityCreateWithAddress(NULL, (struct sockaddr *)&zeroAddress);
    SCNetworkReachabilityFlags flags;

    BOOL didRetrieveFlags = SCNetworkReachabilityGetFlags(defaultRouteReachability, &flags);
    CFRelease(defaultRouteReachability);

    if (!didRetrieveFlags)
    {
        printf("Error. Could not recover network reachability flags\n");
        return NO;
    }

    BOOL isReachable = ((flags & kSCNetworkFlagsReachable) != 0);
    BOOL needsConnection = ((flags & kSCNetworkFlagsConnectionRequired) != 0);

    return (isReachable && !needsConnection) ? YES : NO;
}
8
9.01.2016 13:03:54

Сделать это самостоятельно очень просто. Следующий метод будет работать. Только убедитесь, что вы не разрешаете передавать имя хоста, такое как HTTP, HTTPS и т. Д.

-(BOOL)hasInternetConnection:(NSString*)urlAddress
{
    SCNetworkReachabilityRef ref = SCNetworkReachabilityCreateWithName(kCFAllocatorDefault, [urlAddress UTF8String]);
    SCNetworkReachabilityFlags flags;
    if (!SCNetworkReachabilityGetFlags(ref, &flags))
    {
        return NO;
    }
    return flags & kSCNetworkReachabilityFlagsReachable;
}

Это быстро, просто и безболезненно.

7
9.01.2016 13:05:06

Я нашел это простым и удобным в использовании библиотекой SimplePingHelper .

Пример кода: chrishulbert / SimplePingHelper ( GitHub )

8
9.01.2016 13:06:48

Помимо доступности вы можете также использовать вспомогательную библиотеку Simple Ping . Он работает действительно хорошо и прост в интеграции.

7
9.01.2016 13:07:16

Первый : добавить CFNetwork.frameworkв рамки

Код :ViewController.m

#import "Reachability.h"

- (void)viewWillAppear:(BOOL)animated
{
    Reachability *r = [Reachability reachabilityWithHostName:@"www.google.com"];
    NetworkStatus internetStatus = [r currentReachabilityStatus];

    if ((internetStatus != ReachableViaWiFi) && (internetStatus != ReachableViaWWAN))
    {
        /// Create an alert if connection doesn't work
        UIAlertView *myAlert = [[UIAlertView alloc]initWithTitle:@"No Internet Connection"   message:NSLocalizedString(@"InternetMessage", nil)delegate:nil cancelButtonTitle:@"Ok" otherButtonTitles:nil];
        [myAlert show];
        [myAlert release];
    }
    else
    {
         NSLog(@"INTERNET IS CONNECT");
    }
}
10
9.01.2016 13:08:03

Очень просто .... Попробуйте эти шаги:

Шаг 1: Добавьте SystemConfigurationфреймворк в ваш проект.


Шаг 2: Импортируйте следующий код в ваш headerфайл.

#import <SystemConfiguration/SystemConfiguration.h>

Шаг 3: Используйте следующий метод

  • Тип 1:

    - (BOOL) currentNetworkStatus {
        [UIApplication sharedApplication].networkActivityIndicatorVisible = NO;
        BOOL connected;
        BOOL isConnected;
        const char *host = "www.apple.com";
        SCNetworkReachabilityRef reachability = SCNetworkReachabilityCreateWithName(NULL, host);
        SCNetworkReachabilityFlags flags;
        connected = SCNetworkReachabilityGetFlags(reachability, &flags);
        isConnected = NO;
        isConnected = connected && (flags & kSCNetworkFlagsReachable) && !(flags & kSCNetworkFlagsConnectionRequired);
        CFRelease(reachability);
        return isConnected;
    }

  • Тип 2:

    Заголовок импорта :#import "Reachability.h"

    - (BOOL)currentNetworkStatus
    {
        Reachability *reachability = [Reachability reachabilityForInternetConnection];
        NetworkStatus networkStatus = [reachability currentReachabilityStatus];
        return networkStatus != NotReachable;
    }

Шаг 4: Как использовать:

- (void)CheckInternet
{
    BOOL network = [self currentNetworkStatus];
    if (network)
    {
        NSLog(@"Network Available");
    }
    else
    {
        NSLog(@"No Network Available");
    }
}
15
9.01.2016 13:09:13
Является ли тип 1 асинхронным?
Supertecnoboff 3.10.2018 17:27:18
Я хочу исправления типа 2 из вашего ответа. Я добавил классы достижимости и попытался проверить проверку соединения, используя приведенный выше ваш ответ. он всегда доступен, даже если я подключаюсь по WiFi, но у него нет подключения к интернету. WiFi не означает, что у него есть подключение к интернету. Я хочу проверить подключение к интернету, даже если у него есть подключение к WiFi. Можете ли вы помочь мне?
wesley 29.01.2019 11:54:01

импорт "Reachability.h"

-(BOOL)netStat
{
    Reachability *test = [Reachability reachabilityForInternetConnection];
    return [test isReachable];
}
3
30.09.2014 10:43:33

Я думаю, что это лучший ответ.

«Да» означает «подключен». «Нет» означает «отключен».

#import "Reachability.h"

 - (BOOL)canAccessInternet
{
    Reachability *IsReachable = [Reachability reachabilityForInternetConnection];
    NetworkStatus internetStats = [IsReachable currentReachabilityStatus];

    if (internetStats == NotReachable)
    {
        return NO;
    }
    else
    {
        return YES;
    }
}
7
9.01.2016 13:12:50
  1. Загрузите файл Reachability, https://gist.github.com/darkseed/1182373

  2. И добавить CFNetwork.frameworkи 'SystemConfiguration.framework' в рамках

  3. Сделайте #import "Reachability.h"


Первый : добавить CFNetwork.frameworkв рамки

Код :ViewController.m

- (void)viewWillAppear:(BOOL)animated
{
    Reachability *r = [Reachability reachabilityWithHostName:@"www.google.com"];
    NetworkStatus internetStatus = [r currentReachabilityStatus];

    if ((internetStatus != ReachableViaWiFi) && (internetStatus != ReachableViaWWAN))
    {
        /// Create an alert if connection doesn't work
        UIAlertView *myAlert = [[UIAlertView alloc]initWithTitle:@"No Internet Connection"   message:NSLocalizedString(@"InternetMessage", nil)delegate:nil cancelButtonTitle:@"Ok" otherButtonTitles:nil];
        [myAlert show];
        [myAlert release];
    }
    else
    {
         NSLog(@"INTERNET IS CONNECT");
    }
}
8
9.01.2016 13:14:10