Диспетчер заданий Firebase не работает на устройствах Oreo

Я использую API-интерфейс диспетчера заданий Firebase для запуска службы в фоновом режиме. В Marshmallow он работает нормально, но на устройствах Oreo не работает. он показывает ошибки или предупреждающие сообщения, такие как

2019-02-04 14:20:22.285 2525-5699/? E/NetworkScheduler: удаление задачи, поскольку версия SDK игровых сервисов приложения не поддерживает Android O. Либо обновите SDK, либо уменьшите целевую версию SDK вашего приложения. Пакет: com.webappclouds.jobserviceexample

Я уже сделал то, что упоминается в шаге api диспетчера заданий firebase в git hub.

MainActiviy.java

package com.webappclouds.jobserviceexample;    
import android.app.job.JobInfo;    
import android.app.job.JobScheduler;    
import android.content.ComponentName;    
import android.support.v7.app.AppCompatActivity;    
import android.os.Bundle;    
import android.util.Log;    
import android.view.View;    
import android.widget.Button;    
import com.firebase.jobdispatcher.Constraint;    
import com.firebase.jobdispatcher.FirebaseJobDispatcher;    
import com.firebase.jobdispatcher.GooglePlayDriver;    
import com.firebase.jobdispatcher.Job;    
import com.firebase.jobdispatcher.Lifetime;    
import com.firebase.jobdispatcher.RetryStrategy;    
import com.firebase.jobdispatcher.Trigger;       
public class MainActivity extends AppCompatActivity {

String TAG="MAIN ACTIVITY";
FirebaseJobDispatcher dispatcher;
@Override
protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_main);
    dispatcher = new FirebaseJobDispatcher(new GooglePlayDriver(this));

}

public void startjob(View view) {
    Log.d(TAG, "startjob: ");
    Job job = createJob(dispatcher);
    dispatcher.mustSchedule(job);

}

public void stopjob(View view) {
    Log.d(TAG, "cancelJob: ");
    dispatcher.cancelAll();
}

public Job createJob(FirebaseJobDispatcher dispatcher) {
    Log.d(TAG, "createJob: ");
    Job job = dispatcher.newJobBuilder()
            // persist the task across boots
            .setLifetime(Lifetime.FOREVER)
            // Call this service when the criteria are met.
            .setService(MakeService.class)
            // unique id of the task
            .setTag("LocationJob")
            .setReplaceCurrent(true)
            // We are mentioning that the job is not periodic.
            .setRecurring(true)
           // Run between 30 - 60 seconds from now.
            .setTrigger(Trigger.executionWindow(0, 0))
            .setRetryStrategy(RetryStrategy.DEFAULT_LINEAR)
            // .setTrigger(Trigger.NOW)
            //Run this job only when the network is avaiable.
            .setConstraints(Constraint.ON_ANY_NETWORK)
            .build();
    return job;
}
}

MakeService.java

package com.webappclouds.jobserviceexample;


import android.content.Context;
import android.content.Intent;
import android.os.Handler;
import android.os.SystemClock;
import android.util.Log;


import com.firebase.jobdispatcher.JobService;

import java.util.logging.LogRecord;

import static android.content.ContentValues.TAG;

public class MakeService extends JobService {
    boolean jobintentService=false;
    Handler handler;

    @Override
    public void onCreate() {
        super.onCreate();
        handler= new Handler();
    }


    @Override
    public boolean onStartJob(com.firebase.jobdispatcher.JobParameters job) {
        Log.d(TAG, "onStartJob: ");
        handler.postDelayed(new Runnable() {
            @Override
            public void run() {
                Log.d(TAG, "run: Handler");
                handler.postDelayed(this,10000);
            }
        },10000);
        return true;
    }

    @Override
    public boolean onStopJob(com.firebase.jobdispatcher.JobParameters job) {
        Log.d(TAG, "onStopJob: ");
        return true;
    }

}

Манифест

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

    <uses-permission android:name="android.permission.RECEIVE_BOOT_COMPLETED"/>
    <uses-permission android:name="android.permission.ACCESS_NETWORK_STATE" />
    <uses-permission android:name="android.permission.INTERNET"/>

    <application
        android:allowBackup="true"
        android:icon="@mipmap/ic_launcher"
        android:label="@string/app_name"
        android:roundIcon="@mipmap/ic_launcher_round"
        android:supportsRtl="true"
        android:theme="@style/AppTheme">
        <activity android:name=".MainActivity">
            <intent-filter>
                <action android:name="android.intent.action.MAIN" />

                <category android:name="android.intent.category.LAUNCHER" />
            </intent-filter>
        </activity>
        <service
            android:exported="false"
            android:permission=""
            android:name=".MakeService">
            <intent-filter>
                <action android:name="com.firebase.jobdispatcher.ACTION_EXECUTE"/>
            </intent-filter>
        </service>
    </application>

</manifest>

Сборка (проект)

buildscript {

    repositories {
        google()
        jcenter()
    }
    dependencies {
        classpath 'com.android.tools.build:gradle:3.3.0'
        classpath 'com.google.gms:google-services:4.2.0'


        // NOTE: Do not place your application dependencies here; they belong
        // in the individual module build.gradle files
    }
}

allprojects {
    repositories {
        google()
        jcenter()
    }
}

task clean(type: Delete) {
    delete rootProject.buildDir
}

Сборка (приложение)

apply plugin: 'com.android.application'

android {
    compileSdkVersion 28
    defaultConfig {
        applicationId "com.webappclouds.jobserviceexample"
        minSdkVersion 21
        targetSdkVersion 28
        versionCode 1
        versionName "1.0"
        testInstrumentationRunner "android.support.test.runner.AndroidJUnitRunner"
    }
    buildTypes {
        release {
            minifyEnabled false
            proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro'
        }
    }
}

dependencies {
    implementation fileTree(dir: 'libs', include: ['*.jar'])
    implementation 'com.android.support:appcompat-v7:28.0.0'
    implementation 'com.android.support.constraint:constraint-layout:1.1.3'
    testImplementation 'junit:junit:4.12'
    androidTestImplementation 'com.android.support.test:runner:1.0.2'
    androidTestImplementation 'com.android.support.test.espresso:espresso-core:3.0.2'
    implementation 'com.firebase:firebase-jobdispatcher:0.5.2'

}

Я ожидаю, что это сработает, я не знаю, что происходит.

** РЕШЕНИЕ ** это связано с реализацией версии 'com.firebase:firebase-jobdispatcher:0.8.5', я обновил ее, теперь она работает


person Shekar    schedule 04.02.2019    source источник
comment
это не работает, можно немного конкретнее? вы получаете неожиданное поведение? вы получаете сообщения об ошибках? ..   -  person Stultuske    schedule 04.02.2019
comment
привет, Стултуске. я обновил вопрос. если вам нужно больше, пожалуйста, спросите меня   -  person Shekar    schedule 04.02.2019
comment
Вы прочитали эти сообщения об ошибках и последовали их предложению?   -  person Stultuske    schedule 04.02.2019
comment
я пытался добавить сервис воспроизведения в зависимость от приложения, но он предупреждает, что мы не должны его использовать, он уже поставляется с firebase   -  person Shekar    schedule 04.02.2019


Ответы (2)


Сообщение об ошибке буквально имеет решение

Либо обновите SDK, либо уменьшите целевую версию SDK вашего приложения. Пакет: com.webappclouds.jobserviceexample

Обновите свою библиотеку с 0.5.2

implementation 'com.firebase:firebase-jobdispatcher:0.8.5'

Я также заметил, что у вас есть пустое значение разрешения в вашем манифесте, удалите его.

android:permission=""

Дайте мне знать, если это поможет ????


Я бы порекомендовал вам перейти на WorkManager, так как это более обратно совместимый и более простой API. При использовании этой библиотеки учитываются все ограничения вашего уровня API (ограничения отличаются от безопасности).

Вы можете найти простой пример рабочего процесса здесь:

И документация:

Я рекомендую вам прочитать обе.

person Joaquim Ley    schedule 04.02.2019

пожалуйста, проверьте этот официальный документ Android о Firebase JobDispatcher здесь:

WorkManager — это библиотека для планирования и выполнения отложенной фоновой работы в Android. Это рекомендуемая замена для Firebase JobDispatcher. Следующее руководство проведет вас через процесс миграции вашей реализации Firebase JobDispatcher в WorkManager.

person imansdn    schedule 03.05.2020