Диспетчер заданий Firebase не работает на устройствах Oreo - PullRequest
0 голосов
/ 04 февраля 2019

Я использую 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' Я обновил ее, теперь она работает

1 Ответ

0 голосов
/ 04 февраля 2019

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

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

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

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

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

android:permission=""

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


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

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

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

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

...