Приложение с BroadcastReceiver аварийно завершает работу при загрузке - PullRequest
0 голосов
/ 18 апреля 2019

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

Важно отметить, что служба работает, если она запущена из MainActivity.

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

AndroidManifest.xml

<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    package="nl.arnovanliere.nuntia">

    <uses-permission android:name="android.permission.ACCESS_FINE_LOCATION" />
    <uses-permission android:name="android.permission.ACCESS_COARSE_LOCATION" />
    <uses-permission android:name="android.permission.RECEIVE_BOOT_COMPLETED" />

    <uses-feature android:name="android.hardware.location.gps" />

    <application
        android:allowBackup="true"
        android:fullBackupContent="true"
        android:icon="@mipmap/ic_launcher"
        android:label="@string/app_name"
        android:resizeableActivity="false"
        android:roundIcon="@mipmap/ic_launcher_round"
        android:supportsPictureInPicture="false"
        android:supportsRtl="true"
        android:theme="@style/AppTheme"
        tools:ignore="GoogleAppIndexingWarning">

        <receiver
            android:name=".receivers.BroadcastReceiver"
            android:enabled="true"
            android:exported="true"
            android:permission="android.permission.RECEIVE_BOOT_COMPLETED">
            <intent-filter>
                <action android:name="android.intent.action.BOOT_COMPLETED" />
                <category android:name="android.intent.category.DEFAULT" />
            </intent-filter>
        </receiver>


        <service
            android:name=".services.CheckMessagesService"
            android:enabled="true"
            android:exported="true"
            android:permission="false" />

        <activity
            android:label="@string/app_name"
            android:name=".MainActivity"
            android:theme="@style/AppTheme">
            <intent-filter>
                <action android:name="android.intent.action.MAIN" />

                <category android:name="android.intent.category.LAUNCHER" />
            </intent-filter>
        </activity>

        <meta-data
            android:name="com.google.android.geo.API_KEY"
            android:value="AIzaSyBhlLDqLSihI41pIs-ELuomRWUv6513CeE" />
    </application>

</manifest>

BroadcastReceiver.kt

class BroadcastReceiver : BroadcastReceiver() {
    @SuppressLint("UnsafeProtectedBroadcastReceiver")
    override fun onReceive(context: Context?, intent: Intent?) {
        context?.startService(Intent(context, CheckMessagesService::class.java))
        Log.d(LOG_TAG, "onReceive BroadcastReceiver called")
    }
}

CheckMessagesService

class CheckMessagesService : Service() {

    override fun onBind(intent: Intent): IBinder? {
        return null
    }

    override fun onCreate() {
        Log.d(LOG_TAG, "onCreate of service called")
        super.onCreate()
    }

    override fun onStartCommand(intent: Intent?, flags: Int, startId: Int): Int {
        Log.d(LOG_TAG, "onStartCommand of service called")
        val runnable = Runnable {
            checkMessages()
            // Only need to check for messages every minute
            Thread.sleep(60000)
        }

        // New thread for checking messages, otherwise the UI-thread would be blocked
        val thread = Thread(runnable)
        thread.start()

        return super.onStartCommand(intent, flags, startId)
    }

    override fun onDestroy() {
        Log.d(LOG_TAG, "onDestroy of service called")
        super.onDestroy()
    }

checkMessages () - это просто функция, которая вызывает API и десериализует его для проверки необходимости отправки уведомления.

Надеюсь, один из вас сможет мне помочь.

1 Ответ

0 голосов
/ 20 апреля 2019

Для любых будущих зрителей: проблема заключалась в том, что мне пришлось использовать startForegroundService () вместо startService (), потому что я запускал его на Android Oreo.

Спасибо @ Павел

...