- Android для чайников №13. Android Device Manager: что делать, если потеряли смартфон?
- Павел Крижепольский
- Android Device Manager
- Итоги
- Device Configuration — что это за программа на Андроид и нужна ли она?
- Device Configuration — что это такое?
- Заключение
- Добавить комментарий Отменить ответ
- Служба (Service)
- Создание службы
- Жизненный цикл служб
- Запуск сервиса и управление его перезагрузкой
- Запуск и остановка служб
- PlayService.java
- Пример для Kotlin
- Список всех запущенных сервисов
- Ущемление прав службы
- Системные службы
Android для чайников №13. Android Device Manager: что делать, если потеряли смартфон?
Павел Крижепольский
Я думаю, практически каждый человек хотя бы пару раз попадал в ситуацию, когда не мог вспомнить, куда положил свой смартфон. Обычно, выход в этой ситуация очень простой – нужно просто позвонить на него с любого другого телефона. Но что делать, если на потерянном смартфоне включен беззвучный режим?
Именно такая история и приключилась со мной буквально на днях. Мне нужно было срочно доделать одно важное дело, из-за чего я засиделся за компьютером до трех часов ночи. Время от времени я переписывался с коллегами по почте и скайпу и, чтобы не разбудить домашних постоянными сообщениями о новых письмах, отключил на смартфоне звук. Закончив с делами я лег спать, так и не включив звук на смартфоне. А утром понял, что не могу вспомнить, куда же я его дел.
Вот тут то на помощь и пришел сервис Android Device Manager от компании Google, с которым до этого я был практически незнаком.
Android Device Manager
Как и у всех остальных сервисов Google, у Android Device Manager есть удобный веб интерфейс. Расположен он по адресу https://www.google.com/android/devicemanager
Отдельной регистрации в нем не требуется, для входа достаточно ввести логин и пароль от аккаунта Google.
Google сразу же попытается связаться с вашим устройством и отобразить его местоположение на карте. Если с первой попытки найти телефон не удалось, чуть позже можно попробовать запустить поиск вручную, нажав на иконку «Определение местоположения».
Если вы владелец нескольких Android аппаратов, то нужное устройство можно выбрать нажав на серую стрелочку. А чтобы в дальнейшем избежать путаницы с названиями смартфонов, их лучше сразу изменить на более понятные для вас варианты. Например, «Основной», «Рабочий» или «Семейный планшет».
Итак, благодаря Android Device Manager я узнал, что мой телефон находится где-то в квартире. Но, как вы понимаете, мою задачу это не сильно облегчило. В том, что телефон не мог самостоятельно убежать из дома, я и так не сильно сомневался.
Ситуацию спасла кнопка с надписью «Прозвонить». При нажатии на нее выбранный смартфон зазвонит на максимальной громкости даже в том случае, если находится в беззвучном режиме. Продолжительность звонка – 5 минут. Отключить его раньше можно нажав на клавишу питания телефона.
В моем случае поиски телефона на этом успешно закончились. Но что делать тем, кто забыл свой смартфон в маршрутке или кафе?
Именно для таких случаев Android Device Manager позволяет удаленно заблокировать экран смартфона либо удалить с него все личные данные. Есть только один момент – включить эти функции нужно на своем смартфоне заранее. Сделать это несложно. Достаточно нажать на кнопку «Настроить блокировку и удаление данных», а затем выбрать вариант «Отправить».
В панели уведомлений вашего смартфона должен будет появится специальный значок, после нажатия на который откроется меню настроек. Остается только нажать на кнопку «Активировать» и убедиться, что стоят обе галочки.
Теперь в Android Device Manager рядом с кнопкой «Прозвонить» появились две дополнительные кнопки – «Блокировать» и «Очистить».
Кнопка «Блокировать» позволяет удаленно заблокировать экран смартфона, установив на него цифровой пароль. Кроме того, можно ввести дополнительное сообщение, которое будет отображаться на экране телефона, и ввести номер, на который можно будет позвонить даже не разблокируя аппарат.
С помощью кнопки «Очистить» можно полностью удалить все данные со своего телефона. После этого он вернется к тому состоянию, в котором вы первый раз достали его из коробки.
Для удаленного управления своим смартфоном Google позволяет использовать не только веб интерфейс Android Device Manager, но и специальное приложение. Подробно останавливается на нем не буду, по сути, от веб интерфейса оно ничем не отличается.
Итоги
Android Device Manager – простой, но очень полезный инструмент, который однажды может спасти вам кучу времени, денег и сил. Помнить о его наличии стоит каждому владельцу Android смартфона. Конечно, в случае кражи шансов успешно вернуть телефон в любом случае не очень много. Хотя такие случаи тоже были. Об одном из Эльдар Муртазин не так давно писал в «Бирюльках».
Но даже в этом случае вы сможете заблокировать экран телефона или удалить с него все личные данные, что может спасти вас от многих дополнительных проблем. Например, от звонков с вашего номера друзьям и коллегам, с просьбой перевести деньги на счет или взлома аккаунта в социальной сети.
А вот в случае потери телефона шансы его вернуть заметно возрастут. Во-первых, можно быстро узнать, где именно вы его забыли. Во-вторых, от греха подальше заблокировать экран, написав для нашедшего сообщение о вознаграждении и указав контактный номер телефона. Так и помочь вам будет проще, и соблазна оставить телефон у себя все же меньше.
Так же стоит отметить, что некоторые производители Android смартфонов предлагают для своих аппаратов аналогичные сервисы, часто с более широкими возможностями. К примеру, с обзором фирменного сервиса SamsungDive от компании Samsung вы можете ознакомится по ссылке ниже.
Кроме того, в Google Play существует множество программ со схожими функциями. В качестве примера приведу сервис Norton Mobile Security, обзор которого также есть на нашем сайте.
Какой бы сервис и какую бы программу вы не выбрали, помните, что задуматься о возможной потере или краже смартфона в любом случае нужно заранее. Вы не сможете заблокировать экран утерянного телефона или удалить с него конфиденциальные данные если не активировали эти возможности в его настройках. И тем более, не сможете воспользоваться каким-то сторонним приложением, если заранее не установили его на свой телефон.
Источник
Device Configuration — что это за программа на Андроид и нужна ли она?
Приветствую друзья. Неизвестные программы на смартфоне многих беспокоят, а самое необычное — вы можете ничего не делать, но программы будут появляться. Лично у меня такая ситуация была с телефоном NOUS — да, это китайская модель, но никогда не мог подумать, что рекламные приложения могут быть вшиты в саму прошивку…
Device Configuration — что это такое?
Информация в интернете отсутствует. Именно от слова вообще.
- Например Device Configuration может оказаться системным приложением для аппаратной конфигурации смартфона, для тестирования его, возможно также есть такие настройки как частота приема сигнала, частота работы Wi-Fi, Bluetooth, то есть заводские настройки.
- Неизвестное приложение на Android? Но при этом название похоже на системное? Часто под таким названием скрывается вирус/рекламный модуль, используя такой способ маскировки. Вам стоит просканировать телефон качественным антивирусом, например Касперский, Аваст, но в первую очередь советую Dr.WEB.
Вообще Device Configuration переводится как конфигурация девайса. Под таким названием также может иметься ввиду настройка устройства.
Собственно само приложение в списке (размер подозрительно небольшой):
Также может спокойно оказаться названием пункта в меню:
Заключение
Ребята, мое мнение:
- Сперва просканировать телефон на наличие вирусов.
- При наличии угроз — разумеется удалить их. Не редкость когда вирус присутствует в самой прошивке, особенно касается китайских телефонов и всяких нонеймов.
- В самом крайнем случае сделайте сброс к заводским настройкам (хард ресет).
Добавить комментарий Отменить ответ
Этот сайт использует Akismet для борьбы со спамом. Узнайте как обрабатываются ваши данные комментариев.
Источник
Служба (Service)
Службы (Сервисы) в Android работают как фоновые процессы и представлены классом android.app.Service. Они не имеют пользовательского интерфейса и нужны в тех случаях, когда не требуется вмешательства пользователя. Сервисы работают в фоновом режиме, выполняя сетевые запросы к веб-серверу, обрабатывая информацию, запуская уведомления и т.д. Служба может быть запущена и будет продолжать работать до тех пор, пока кто-нибудь не остановит её или пока она не остановит себя сама. Сервисы предназначены для длительного существования, в отличие от активностей. Они могут работать, постоянно перезапускаясь, выполняя постоянные задачи или выполняя задачи, требующие много времени.
Клиентские приложения устанавливают подключение к службам и используют это подключение для взаимодействия со службой. С одной и той же службой могут связываться множество клиентских приложений.
Android даёт службам более высокий приоритет, чем бездействующим активностям, поэтому вероятность того, что они будут завершены из-за нехватки ресурсов, заметно уменьшается. По сути, если система должна преждевременно завершить работу запущенного сервиса, он может быть настроен таким образом, чтобы запускаться повторно, как только станет доступно достаточное количество ресурсов. В крайних случаях прекращение работы сервиса (например, задержка при проигрывании музыки) будет заметно влиять на впечатления пользователя от приложения, и в подобных ситуациях приоритет сервиса может быть повышен до уровня активности, работающей на переднем плане.
Используя сервис, можете быть уверены, что ваши приложения продолжат работать и реагировать на события, даже если они в неактивном состоянии. Для работы службам не нужен отдельный графический интерфейс, как в случае с активностями, но они по-прежнему выполняются в главном потоке хода приложения. Чтобы повысить отзывчивость вашего приложения, нужно уметь переносить трудоёмкие процессы (например, сетевые запросы) в фоновые потоки, используя классы Thread и AsyncTask.
Службы идеально подходят для проведения постоянных или регулярных операций, а также для обработки событий даже тогда, когда активности вашего приложения невидимы, работают в пассивном режиме или закрыты.
Сервисы запускаются, останавливаются и контролируются из различных компонентов приложения, включая другие сервисы, активности и приёмники широковещательных намерений. Если ваше приложение выполняет задачи, которые не зависят от прямого взаимодействия с пользователем, сервисы могут стать хорошим выбором.
Запущенные сервисы всегда имеют больший приоритет, чем бездействующие или невидимые активности, поэтому менее вероятно, что их работа завершится преждевременно при распределении ресурсов. Единственная причина, почему Android может досрочно остановить Сервис, — выделение дополнительных ресурсов для компонентов, работающих на переднем плане (как правило, для активностей). Если такое случится, ваш сервис автоматически перезапустится, когда будет достаточно доступных ресурсов.
Когда сервис напрямую взаимодействует с пользователем (например, проигрывая музыку), может понадобиться повысить его приоритет до уровня активностей, работающих на переднем плане. Это гарантия того, что сервис завершится только в крайнем случае, но при этом снижается его доступность во время выполнения, мешая управлять ресурсами, что может испортить общее впечатление от приложения.
Приложения, которые регулярно обновляются, но очень редко или нерегулярно взаимодействуют с пользователем, можно назвать первыми кандидатами на реализацию в виде сервисов. Проигрыватели MP3 и приложения, отслеживающие спортивные результаты, — примеры программ, которые должны постоянно работать и обновляться без необходимости отображать активность.
Создание службы
Чтобы определить службу, необходимо создать новый класс, расширяющий базовый класс Service. Можно воспользоваться готовым мастером создания класса для сервиса в Android Studio. Щёлкаем правой кнопкой мыши на папке java (или на имени пакета) и выбираем New | Service | Service:
В следующем окне выбираем имя сервиса (флажки оставляем) и нажимаем кнопку Finish.
При этом сервис автоматически зарегистрируется в манифесте в секции .
Если бы мы убрали флажки на экране мастера, то оба атрибута имели бы значение false. Например, атрибут exported даёт возможность другим приложениям получить доступ к вашему сервису.
Имеются и другие атрибуты, например, permission, чтобы сервис запускался только вашим приложением.
Также вы можете обойтись без мастера и создать вручную класс сервиса и запись в манифесте, теперь вы знаете, из чего он состоит.
Жизненный цикл служб
Подобно активностям служба имеет свои методы жизненного цикла:
Для быстрого создания заготовок нужных методов используйте команду меню Code | Override Methods. или набирайте сразу имя метода, используя автодополнение.
Реализуя эти методы обратного вызова в своей службе, вы можете контролировать жизненные циклы службы. В полном жизненном цикле службы существует два вложенных цикла:
- полная целая жизнь службы — промежуток между временем вызова метода onCreate() и временем возвращения onDestroy(). Подобно активности, для служб производят начальную инициализацию в onCreate() и освобождают все остающиеся ресурсы в onDestroy()
- активная целая жизнь службы — начинается с вызова метода onStartCommand(). Этому методу передаётся объект Intent, который передавали в метод startService().
Из своего приложения службу можно запустить вызовом метода Context.startService(), остановить через Context.stopService(). Служба может остановить сама себя, вызывая методы Service.stopSelf() или Service.stopSelfResult().
Можно установить подключение к работающей службе и использовать это подключение для взаимодействия со службой. Подключение устанавливают вызовом метода Context.bindService() и закрывают вызовом Context.unbindService(). Если служба уже была остановлена, вызов метода bindService() может её запустить.
Методы onCreate() и onDestroy() вызываются для всех служб независимо от того, запускаются ли они через Context.startService() или Context.bindService().
Если служба разрешает другим приложениям связываться с собой, то привязка осуществляется с помощью дополнительных методов обратного вызова:
- IBinder onBind(Intent intent)
- onUnbind(Intent intent)
- onRebind(Intent intent)
В метод обратного вызова onBind() передают объект Intent, который был параметром в методе bindService(), а в метод обратного вызова onUnbind() — объект Intent, который передавали в метод unbindService(). Если служба разрешает связывание, метод onBind() возвращает канал связи, который используют клиенты, чтобы взаимодействовать со службой. Метод обратного вызова onRebind() может быть вызван после onUnbind(), если новый клиент соединяется со службой.
Запуск сервиса и управление его перезагрузкой
В большинстве случаев также необходимо переопределить метод onStartCommand(). Он вызывается каждый раз, когда сервис стартует с помощью метода startService(), поэтому может быть выполнен несколько раз на протяжении работы. Вы должны убедиться, что ваш сервис это предусматривает.
Метод onStartCommand() заменяет устаревший метод onStart(), который использовался в Android 2.0. В отличие от onStart() новый метод позволяет указать системе, каким образом обрабатывать перезапуски, если сервис остановлен системой без явного вызова методов stopService() или stopSelf().
Службы запускаются в главном потоке приложения; это значит, что любые операции, выполняющиеся в обработчике onStartCommand(), будут работать в контексте главного потока GUI. На практике при реализации сервиса в методе onStartCommand() создают и запускают новый поток, чтобы выполнять операции в фоновом режиме и останавливать сервис, когда работа завершена.
Такой подход позволяет методу onStartCommand() быстро завершить работу и даёт возможность контролировать поведение сервиса при его повторном запуске, используя одну из констант.
- START_STICKY — Описывает стандартное поведение. Похоже на то, как был реализован метод onStart() в Android 2.0. Если вы вернёте это значение, обработчик onStartCommand() будет вызываться при повторном запуске сервиса после преждевременного завершения работы. Обратите внимание, что аргумент Intent, передаваемый в onStartCommand(), получит значение null. Данный режим обычно используется для служб, которые сами обрабатывают свои состояния, явно стартуя и завершая свою работу при необходимости (с помощью методов startService() и stopService()). Это относится к службам, которые проигрывают музыку или выполняют другие задачи в фоновом режиме
- START_NOT_STICKY — Этот режим используется в сервисах, которые запускаются для выполнения конкретных действий или команд. Как правило, такие службы используют stopSelf() для прекращения работы, как только команда выполнена. После преждевременного прекращения работы службы, работающие в данном режиме, повторно запускаются только в том случае, если получат вызовы. Если с момента завершения работы Сервиса не был запущен метод startService(), он остановится без вызова обработчика onStartCommand(). Данный режим идеально подходит для сервисов, которые обрабатывают конкретные запросы, особенно это касается регулярного выполнения заданных действий (например, обновления или сетевые запросы). Вместо того, чтобы перезапускать сервис при нехватке ресурсов, часто более целесообразно позволить ему остановиться и повторить попытку запуска по прошествии запланированного интервала
- START_REDELIVER_INTENT — В некоторых случаях нужно убедиться, что команды, которые вы посылаете сервису, выполнены. Этот режим — комбинация предыдущих двух. Если система преждевременно завершила работу сервиса, он запустится повторно, но только когда будет сделан явный запрос на запуск или если процесс завершился до вызова метода stopSelf(). В последнем случае вызовется обработчик onStartCommand(), он получит первоначальное намерение, обработка которого не завершилась должным образом.
Обратите внимание, что при окончании всех операций каждый из этих режимов требует явной остановки сервиса с помощью методов stopService() или stopSelf().
Режим перезапуска, который вы указываете в качестве значения, возвращаемого методом onStartCommand(), будет влиять на параметры, передаваемые при последующих вызовах.
Изначально намерение выступает в качестве параметра, который передастся в метод startService() при запуске сервиса. После перезапуска системой он может иметь значение null (если установлен режим START_STICKY) или оригинальное (если установлен флаг START_REDELIVER_INTENT).
Параметр flag может помочь узнать, как именно был запущен сервис:
- START_FLAG_REDELIVERY — указывает на то, что параметр Intent повторно передан при принудительном завершении работы сервиса перед явным вызовом метода stopSelf()
- START_FLAG_RETRY — указывает на то, что сервис повторно запущен после непредвиденного завершения работы; передается в том случае, если ранее сервис работал в режиме START_STICKY
Запуск и остановка служб
Чтобы запустить службу, в клиентском приложении необходимо вызывать метод startService(). Существует два способа вызова службы:
Пример для явного вызова службы с именем MyService:
Также можно явно определить службу, создав экземпляр класса этой службы.
Пример неявного вызова службы:
Чтобы использовать этот пример, необходимо включить константу SERVICE_ACTION, идентифицирующую службу, в класс MyService, например:
Используйте фильтр намерений, чтобы зарегистрировать его как провайдера SERVICE_ACTION. Если служба потребует разрешений, которые не имеет ваше приложение, то запрос вызовет исключение SecurityException.
Как только сервис завершил выполнение тех действий, для которых он запускался, вы должны вызвать метод stopSelf() либо без передачи параметра, чтобы ускорить остановку работы, либо передав значение startId, чтобы убедиться, что задачи выполнены для всех экземпляров, запущенных с помощью вызова startService(), как показано в следующем фрагменте:
Явная остановка сервиса по завершении необходимых задач позволяет системе получать обратно ресурсы, которые в ином случае оставались бы заняты. Поскольку приоритет сервисов повышенный, система, как правило, не завершает их работу, поэтому её окончание по собственной инициативе может существенно улучшить эффективность использования ресурсов вашим приложением.
Для остановки работы используйте метод stopService(), передавая ему объект Intent, определяющий нужный сервис.
Если метод startService() вызывается для сервиса, который уже работает, обработчик onStartCommand(), принадлежащий объекту Service, будет вызван повторно. Вызовы startService() не накапливаются, поэтому единственный вызов метода stopService() завершит работу сервиса, неважно, сколько раз производился вызов startService().
Давайте создадим практическое приложение для работы со службой. Наша служба будет запускать на воспроизведение музыкальный файл, который будет проигрываться в фоновом режиме. Управлять службой можно будет из активности. Создайте новый проект. Для службы создайте отдельный класс PlayService. Служба будет загружать музыкальный файл sample.mp3 из каталога res/raw/ (разместите там свой MP3-файл).
PlayService.java
Зарегистрируем службу в файле манифеста.
В файле разметки для активности определим две кнопки: Старт и Стоп:
В классе активности в обработчиках событий кнопок будем вызывать методы startService() и stopService() для управления службой.
Запущенная служба будет выполняться независимо от состояния активности, несмотря на то, что эти компоненты находятся в одном приложении: если её завершить, служба все равно останется работать.
Если вы хотите, чтобы сервис запускался и после перезагрузки устройства, то следует создать приёмник широковещательных сообщений и запустить в нём сервис.
Приёмник регистрируется в манифесте с именем действия BOOT_COMPLETED:
Пример для Kotlin
Класс для службы, которая будет генерировать случайные числа через определённый промежуток времени. Не забудьте прописать службу в манифесте.
Разместите на экране активности три кнопки: запуск, остановка и статус службы. Код для активности.
Список всех запущенных сервисов
Ущемление прав службы
Google последовательно борется с ограничениями для служб, урезая их возможности. Делается это для того, чтобы службы не висели в памяти бесконечно долго и тратили заряд батареи. Ограничение возможностей происходит постепенно от версии к версии. В последних версиях уже можно столкнуться с примерами, когда выкидывается исключение при неправильной работе с службами.
Для решения проблем следует изучить такие вещи как JobScheduler, Firebase Job Dispatcher, WorkManager. Также появилось понятие Foreground service.
Системные службы
Кроме создания собственных сервисов, вы можете использовать системные сервисы. Вот небольшой список:
- Account Service — служба для управления пользовательскими учётными записями
- Activity Service — служба для управления активностями
- Alarm Service — служба для отправки разовых или периодических оповещений в заданное время
- Bluetooth Service — служба для Bluetooth
- Clipboard Service — служба для управления буфером обмена
- Connectivity Service — служба для управления сетевыми соединениями
- Download Service — служба для управления загрузками
- Input Method Service — служба для управления текстовым вводом
- JobScheduler — служба для планирования задач
- Location Service — служба для отслеживания координат
- Layout Inflater Service — служба для управления компоновкой экрана при динамическом создании из кода
- NFC Service — служба для управления NFC
- Notification Service — служба для управления уведомлениями
- Power Service — служба для управления энергопотреблением
- Search Service — служба для управления глобальным поиском
- Sensor Service — служба для доступа к датчикам
- Telephony Service — служба для управления телефонными функциями
- Vibrator Service — служба для доступа к виброзвонку
- Wallpaper Service — служба для управления обоями на домашнем экране
- Wifi Service — служба для управления соединениями Wi-Fi
Источник