Android studio wifi проверка подключения

Обновлено: 06.07.2024

согласно сайту разработчика Android,определение и мониторинг состояния подключения, мы можем проверить есть активное подключение к интернету. Но это не работает, если даже подключен только Wi-Fi и не доступен Интернет (он уведомляет о наличии подключения к интернету).

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

это очень просто и быстро:

тогда везде, где вы хотите проверить, просто используйте это:

не забудьте доступ:

первая проблема, которую вы должны прояснить, - это то, что вы подразумеваете под whether internet is available ?

  • не подключен к wifi или сотовой сети;
  • подключен к ограниченному wifi: например, в школьной сети, Если вы подключаетесь к школе wifi, вы можете получить доступ к интрасети напрямую. Но вы должны войти в систему с учетной записи, доступ к экстрасети. В этом случае, если вы ping веб-сайт Экстранет, вы можете получить ответ, потому что некоторые интрасети сделали автоматическое перенаправление для входа в систему страница;
  • подключен к неограниченному wifi: вы можете получить доступ к большинству веб-сайтов;

вторая проблема заключается в том, чего вы хотите достичь?

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

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

В заключение, у нас нет лучшего способа проверить подключение к хосту, кроме ping it, вот почему пульс используется в управлении сервисом.

это будет проверять только whther Ther активное соединение wifi.

поэтому я нашел 2 метода, которые проверят, есть ли активное подключение к интернету

1.Ping веб-сайт с помощью ниже метод

2.Проверьте наличие Google DNS с помощью сокета

второй метод немного быстрее, чем 2-й метод (который подходит для моего требования)

спасибо всем за ответы и поддержку.

ConnectivityManager не сможет сообщить вам, есть ли у вас активное соединение по WIFI.

Что вы можете сделать:

используйте ниже код для проверки подключения

Я хочу создать приложение, которое использует интернет, и я пытаюсь создать функцию, которая проверяет, доступно ли соединение, а если нет, перейдите к действию, которое имеет кнопку повтора и объяснение.

прилагается мой код до сих пор, но я получаю ошибку Syntax error, insert ">" to complete MethodBody.

теперь я помещаю их в попытке заставить его работать, но до сих пор не повезло. Любая помощь будет оценена по достоинству.

этот метод проверяет, подключен ли мобильный телефон к интернету и возвращает true, если он подключен:

в манифесте,

Edit: Этот метод фактически проверяет, подключено ли устройство к интернету (есть возможность, что оно подключено к сети, но не к интернету).

вы можете просто пинговать онлайн-сайт, как google:

вышеуказанные методы работают, когда вы подключены к источнику Wi-Fi или через пакеты данных сотового телефона. Но в случае подключения Wi-Fi есть случаи, когда вас дополнительно просят войти в систему, как в кафе. Так что в этом случае ваше приложение не удастся, как вы подключены к источнику Wi-Fi, но не с Интернетом.

этот метод работает отлично.

пожалуйста, используйте это в отдельном потоке от основного потока, как это делает сетевой вызов и будет бросать NetwrokOnMainThreadException если не следовать.

а также не помещайте этот метод в onCreate или любой другой метод. Поместите его в класс и получите к нему доступ.

редактирование принятого ответа показывает, как проверить, можно ли что-то в интернете. Мне пришлось слишком долго ждать ответа, когда это было не так (с Wi-Fi, который не имеет подключения к интернету). К Сожалению InetAddress.getByName не имеет параметра timeout, поэтому следующий код работает вокруг этого:

вы не можете создать метод внутри другого метода, перемещение private boolean checkInternetConnection() < способ из onCreate

вы можете использовать следующий фрагмент для проверки подключения к интернету.

это будет полезно в обоих случаях, что вы можете проверить, какие тип сеть Соединение доступно, так что вы можете сделать свой процесс на этом пути.

вы просто должны скопировать следующий класс и вставить непосредственно в пакет.

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

Не забудьте взять разрешение :) :)

вы можете изменить на основе ваших требований.

все официальные методы только говорит, открыто ли устройство для сети или нет,
если ваше устройство подключено к Wi-Fi, но Wifi не подключен к интернету, то этот метод не будет работать (что происходит много раз), никакой встроенный метод обнаружения сети не расскажет об этом сценарии, поэтому созданный асинхронный класс обратного вызова, который вернется в onConnectionSuccess и onConnectionFail

сетевой вызов из асинхронного режима Задача

фактический класс, который будет пинговать на сервер

не нужно быть сложным. Самый простой и рамочный способ-использовать ACCESS_NETWORK_STATE разрешение и просто сделать подключенный метод

вы также можете использовать requestRouteToHost Если у вас есть particualr хост и тип подключения (wifi/mobile) в виду.

вы должны:

в вашем манифесте android.

для более подробной информации иди сюда

Однажды мне понадобилось сканировать из Android приложения сети Wi-Fi и получать подробную выкладку данных о точках доступа.

Тут пришлось столкнуться с несколькими трудностями: в офф.документации Android многие описанные классы стали deprecated (API level > 26), что никак не было в ней отражено; описание некоторых вещей в документации минимально (например поле capabilities класса ScanResult на момент написания не описано почти никак, хотя содержит много важных данных). Третья сложность может заключаться в том, что при первой близости с Wi-Fi, отличной от чтения теории и настройки роутера по localhost, приходится иметь дело с рядом аббревиатур, которые кажутся понятными по отдельности. Но может быть не очевидно, как их соотнести и структурировать (суждение субъективно и зависит от предыдущего опыта).

В данной статье рассмотрено как из Android кода получить исчерпывающие данные о Wi-Fi окружении без NDK, хаков, а лишь с помощью Android API и понять, как их интерпретировать.

Не будем тянуть и начнем писать код.

1. Создаем проект

Заметка рассчитана на тех, кто больше одного раза создавал Android проект, поэтому подробности данного пункта опускаем. Код ниже будет представлен на языке Kotlin, minSdkVersion=23.

2. Разрешения на доступы

Для работы с Wi-Fi из приложения понадобится получить от пользователя несколько разрешений. В соответствии с документацией, для того, чтобы осуществить сканирование сети на устройствах с ОС версий после 8.0, помимо доступа к просмотру состояния сетевого окружения нужен либо доступ на изменение состояния модуля Wi-Fi устройства, либо доступ к координатам (примерным или точным). Начиная с версии 9.0 необходимо запросить у пользователя и то и то, и при этом явно запросить у пользователя включить службу определения местоположения. Не забываем галантно объяснять пользователю, что это прихоть компании Google, а не наше желание устроить за ним слежку :)

Итого, в AndroidManifest.xml добавим:


А в коде, в котором есть ссылка на текущую Activity:

3. Создаем BroadcastReceiver и подписываемся на события обновления данных о сканировании сетевого окружения Wi-Fi

Метод WiFiManager.startScan в документации помечен как depricated с версии API 28, но офф. guide предлагает использовать его.

Итого, получили список объектов ScanResult.

4. Смотрим на ScanResult и разбираемся в терминах

Посмотрим на некоторые поля этого класса и опишем, что они означают:

SSID — Service Set Identifier – это название сети

BSSID – Basic Service Set Identifier – MAC адрес сетевого адаптера (Wi-Fi точки)

level — Received Signal Strength Indicator [dBm (русское дБм) — Децибел, опорная мощность 1 мВт.] — Показатель уровня принимаемого сигнала. Принимает значение от 0 до -100, чем дальше от 0, тем больше мощности сигнала потерялось по пути от Wi-Fi точки к вашему устройству. Подробнее можно посмотреть например на Википедии. Здесь же расскажу, что с помощью Android класса WifiManager можно проградуировать уровень сигнала по шкале от отличного до ужасного с выбранным вами шагом:


frequency — частота работы точки Wi-Fi [Гц]. Помимо самой частоты вас может заинтересовать так называемый канал. У каждой точки есть своя рабочая чистота. На момент написания текста наиболее популярным диапозоном Wi-Fi точек является 2.4 GHz. Но, если быть точнее, точка передает информацию на ваш телефон на пронумерованной частоте, близкой к названной. Количество каналов и значения соответствующих частот стандартизованы. Это сделано для того, чтобы точки поблизости работали на разных частотах, тем самым не создавая помехи друг другу и взаимно не понижая скорость и качество передачи. При этом точки работают не на одной частоте, а на диапазоне частот (пареметр channelWidth), называемом шириной канала. То есть точки, работающие на соседних (и не только на соседних, а даже на 3 от себя) каналах создают друг другу помехи. Вам может пригодится этот незамысловатый код, который позволяет вычислить номер канала по значению частоты для точек с частотой 2.4 и 5 Ghz:


capabilities — наиболее интересное поле для анализа, работа с которым потребовало много времени. Тут в строку записываются «возможности» точки. При этом подробности интерпритации строки в документации можно не искать. Вот несколько примеров того, что может лежать в этой строке:

5. Разбираемся в аббревиатурах и парсим capabilities

Будем действовать последовательно. Рассмотрим сначала вывод такого формата, при котором внутри скобок элементы отделены знаком "-":


Первое значение описывает т.н. метод аутентификации (authentication). То есть, какую последовательность действий должны произвести устройство и точка доступа, чтобы точка доступа позволила собой пользоваться и каким образом шифровать полезную нагрузку. На момент написания поста самые частые варианты это WPA и WPA2, при котором либо каждое подключаемое устройство напрямую, либо через т.н. RADIUS-сервер (WPA-Enterprice) предоставляет пароль по зашифрованному каналу. Скорее всего у вас дома точка доступа предоставляет подключение по этой схеме. Отличие второй версии от первой в болеее стойком шифре: AES против небезопасного TKIP. Также постепенно внедряется WPA3, более сложный и продвинутый. Теоритически может встретиться вариант с enterprice-решением CCKM (Cisco Centralized Key Managment), но мне так и не встретился.

Точка доступа могла быть настроена на аутентификацию по MAC-адресу. Или, если точка доступа предоставляет данные по устаревшему алгоритму WEP, то аутентификации фактически нет (секретный ключ тут и является ключом шифрования). Такие варианты отнесем к типу OTHER.
Ещё есть полюбившийся в общественных wi-fi метод со скрытым Captive Portal Detection — запрос аутентификации через браузер. Такие точки доступа выглядят для сканера как открытые (какими с точки зраения физического подключения и являются). Поэтому отнесем их к типу OPEN.

Второе значение можно обозначить как алгоритм использования ключей (key management). Является параметром метода аутентификации, о котором написано выше. Говорит о том, как именно происходит обмен ключами шифрования. Рассмотрим возможные варианты. EAP — используется в упомянутом WPA-Enterprice, использует базу данных для сверки введеных аутентификационных данных. SAE — используется в продвинутом WPA3, более устойчива к перебору. PSK — самый частый вариант, подразумевает ввод пароля и его передачу в зашифрованном виде. IEEE8021X — по международному стандарту (отличному от поддержанным семейством WPA). OWE (Opportunistic Wireless Encryption) является расширением стандарта IEEE 802.11, для точек, которые мы отнесли к типу OPEN. OWE обеспечивает безопасность данных, передаваемых по незащищенной сети, за счет их шифрования. Также возможен варинант когда ключей доступа нет, назовем такой вариант NONE.

Третьим параметром является т.н. метод шифрования (encryption schemes) — как именно используется шифр для зашиты передаваемых данных. Перечислим варианты. WEP — использует поточный шифр RC4, секретный ключ является ключом шифрования, что в мире современной криптографии считается неприемлемым. TKIP — используется в WPA, CKIP — в WPA2. TKIP+CKIP — может быть указан в точках умеющих WPA и WPA2 для обратной совместимости.

Вместо трех элементов можно встретить одинокую пометку WEP:


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

Теперь рассмотрим такую скобочку:


Это режим работы Wi-Fi или топология сетей Wi-Fi. Вам может встретиться Режим BSS (Basic Service Set) — когда есть одна точка доступа, через которую общаются подключенные устройства. Можно встретить в локальных сетях. Как правило точки доступа нужны для того, чтобы соединять устройства из разных локальных сетей, поэтому они являются частью Extended Service Sets — ESS. Тип IBSSs (Independent Basic Service Sets) говорит о том, что устройство является частью Peer-to-Peer сети.

Ещё может попасться флаг WPS:

6. Создаем модель и функцию парсинга

На основе того, что выяснили выше опишем data-классами то, что получилось:


Теперь напишем функцию, которая будет парсить поле capabilities:

8. Смотрим результат

Посканирую сеть и покажу, что получилось. Показаны результаты простого вывода через Log.d:

Спасибо Егору Пономареву за ценные дополнения.


где context – используем текущую Activity , т.е. this ; - text – текст, который надо показать; — duration – продолжительность показа ( Toast.LENGTH_LONG — длинная, Toast.LENGTH_SHORT — короткая); - show () – отображение на экране.

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

isConncted_emul

Выводим состояние сети либо wi–fi либо мобильный интернет.

Ниже на рисунках пример работы:

Ниже на рисунках пример работы:

connect_emul

wi-fi_emul

Теперь в методе onCreate, который отвечает за установку параметров и инициализации активности, переопределим методы для выше описанного класса. Зарегистрируем объект данного класса в системе, и с помощью фильтра IntentFilter получаем необходимое событие, а именно изменение сетевого подключения. Если параметры нашего Intent совпадают с условиями этого фильтра, то Activity вызывается. Ниже код.

Этот метод предназначен для использования в эмулируемых средах обработки. Он никогда не будет вызываться на реальном устройстве Android, где процессы удаляются, просто убивая их. При этом не выполняется код пользователя (включая этот обратный вызов).
Если вы переопределите этот метод, вы должны выполнить вызов суперкласса.
Для просмотра сетей Wi-Fi и вывода информации создадим еще один класс и наследуемся от BroadcastReceiver.

И будем производить поиск сетей по нажатию на кнопку. Ниже код и рисунок работы на эмуляторе и реальном устройстве. Работу с кнопкой в Android-приложении мы частично рассматривали в прошлой статье а также в приложении подключения AVR к ОС Android.

skan_wi_fi
scan

Для работы данного приложения необходимо внести разрешения в файл Манифеста, , в корневом теге <manifest>.

где первый получает доступ к приблизительному местоположению, второй — приложение сможет получать доступ к точному местоположению. Два последних разрешения являются опасными.
И в методе OnCreate пропишем следующую строку.

Все, добавляем код в наше приложение SmartHouse. Теперь мы имеем доступ к сетям. В последующем мы выведем сети Wi-Fi в листинг и научимся выбирать определенную и подключаться к ней. В следующей статье вернемся к контроллеру STM32 и свяжем его с ESP8266, который по нашей задумке будет управляющим элементом в системе умный дом. На этом сегодня и остановимся. Всем пока.

Читайте также: