首先感谢您的回复。 :)
在过去的几个月中,我一直在为Android开发许多后台日志记录应用程序。它们用于学术研究。自从android 8.1发布以来,我发现运行前台服务存在许多问题,但是最大的问题是前台服务无法在启动时重启。这适用于之前的每个SDK。
我已经构建了一个应用程序来解决此问题。我只是试图确认作业调度程序已从广播接收器激活。因此,数据内部存储在文件“ data.txt”中。
这是我的代码,用于在启动时重新启动前台服务。
public class startServiceOnBoot extends BroadcastReceiver {
@Override
public void onReceive(Context context, Intent intent) {
if (Intent.ACTION_BOOT_COMPLETED.equals(intent.getAction())) {
Intent serviceIntent = new Intent();
serviceIntent.addFlags(Intent.FLAG_ACTIVITY_NEW_TASK);
serviceIntent.setAction("geyer.sensorlab.jobschedulepractice.StartMyActivityAtBootReceiver");
Bundle b=new Bundle();
b.putBoolean("from main", true);
serviceIntent.putExtras(b);
Worker.enqueueWork(context, serviceIntent);
}
}
}
工作意向服务
public class Worker extends JobIntentService {
private static final String TAG = "Worker";
public static final int SHOW_RESULT = 123;
static final int DOWNLOAD_JOB_ID = 1000;
public static void enqueueWork(Context context, Intent intent) {
enqueueWork(context, Worker.class, DOWNLOAD_JOB_ID, intent);
}
@Override
protected void onHandleWork(@NonNull Intent intent) {
Log.d(TAG, "onHandleWork() called with: intent = [" + intent + "]");
if(Objects.requireNonNull(intent.getExtras()).getBoolean("from main")){
storeInternally("from main");
}else{
storeInternally("from restart");
}
}
private void storeInternally(String result) {
long timestamp = System.currentTimeMillis()/1000;
String dataEntry = result + " - " + timestamp + ": ";
try {
File path = this.getFilesDir();
File file = new File(path, "data.txt");
FileOutputStream fos = new FileOutputStream(file, true);
fos.write(dataEntry.getBytes());
fos.close();
Log.i("from screen service", dataEntry);
} catch (Exception e) {
Log.d("Main - issue writing", "Exception: " + e);
}
}
}
和清单:
<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">
<uses-permission android:name="android.permission.RECEIVE_BOOT_COMPLETED"/>
<intent-filter>
<action android:name="android.intent.action.MAIN" />
<category android:name="android.intent.category.LAUNCHER" />
</intent-filter>
</activity>
<receiver android:name=".startServiceOnBoot"
android:label="StartMyServiceAtBootReceiver">
<intent-filter>
<action android:name="android.intent.action.BOOT_COMPLETED"/>
<action android:name="android.intent.action.QUICKBOOT_POWERON"/>
</intent-filter>
</receiver>
<service android:name=".Worker"
android:permission="android.permission.BIND_JOB_SERVICE"/>
<service android:name=".target"/>
</application>
谁能看到我所缺少的东西?
答案 0 :(得分:1)
我遇到了同样的问题。 而且,当我授予我的应用程序“自动启动”权限时,它就起作用了。
下面提供的代码段将带您进入“自动启动权限”屏幕,在此处您可以手动授予该权限。
try
{
//Open the specific App Info page:
Intent intent = new Intent(android.provider.Settings.ACTION_APPLICATION_DETAILS_SETTINGS);
intent.setData(Uri.parse("package:" + context.getPackageName()));
context.startActivity(intent);
}
catch ( ActivityNotFoundException e )
{
//Open the generic Apps page:
Intent intent = new Intent(android.provider.Settings.ACTION_MANAGE_APPLICATIONS_SETTINGS);
context.startActivity(intent);
}
答案 1 :(得分:0)
自奥利奥(Oreo)起,不允许从后台启动服务,启动接收器就是这种情况。幸运的是,您可以通过延迟JobIntent API来完成此任务,该API会在稍后启动,但是仍然可以保证迟早启动。
public class BootReceiver extends BroadcastReceiver {
@Override
public void onReceive(Context context, Intent intent) {
if (Intent.ACTION_BOOT_COMPLETED.equals(intent.getAction())) {
MyService.enqueueWork(context, new Intent());
}
}
}
请查看this medium post,以获得更详细的答案和代码。