当我将 PowerManager.WakeLock 与 AlaramManager android 一起使用时出现权限异常
Permission Exception when I use PowerManager.WakeLock with AlaramManager android
我正在开发一个本机 android 应用程序,每 30 分钟 运行 一些操作。
我需要确保处理器是 运行ning,所以我使用了
PowerManager.Wakelock 报警接收器内。
这是我在内部用于警报接收器的代码。
public class AlarmReceiver extends BroadcastReceiver {
@Override
public void onReceive(Context context, Intent arg1) {
PowerManager pm = (PowerManager) context.getSystemService(context.POWER_SERVICE);
PowerManager.WakeLock wl = pm.newWakeLock(PowerManager.PARTIAL_WAKE_LOCK, "My Tag");
wl.acquire();
Intent eventService = new Intent(context, SyncInBackground.class);
context.startService(eventService);
wl.release();
}
}
并且在我的主要 AndroidManifest.xml
我添加了以下行来请求权限
<uses-permission android:name="android.permission.wake_lock"/>
当我在应用程序中 运行 发出警报时,出现以下异常
02-07 23:25:02.839 13699-13699/com.snappext E/AndroidRuntime﹕ FATAL EXCEPTION: main
java.lang.RuntimeException: Unable to start receiver com.snappext.Backup.AlarmReceiver: java.lang.SecurityException: Neither user 10008 nor current process has android.permission.WAKE_LOCK.
at android.app.ActivityThread.handleReceiver(ActivityThread.java:2140)
at android.app.ActivityThread.access00(ActivityThread.java:127)
at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1211)
at android.os.Handler.dispatchMessage(Handler.java:99)
at android.os.Looper.loop(Looper.java:137)
at android.app.ActivityThread.main(ActivityThread.java:4512)
at java.lang.reflect.Method.invokeNative(Native Method)
at java.lang.reflect.Method.invoke(Method.java:511)
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:982)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:749)
at dalvik.system.NativeStart.main(Native Method)
Caused by: java.lang.SecurityException: Neither user 10008 nor current process has android.permission.WAKE_LOCK.
at android.os.Parcel.readException(Parcel.java:1327)
at android.os.Parcel.readException(Parcel.java:1281)
at android.os.IPowerManager$Stub$Proxy.acquireWakeLock(IPowerManager.java:381)
at android.os.PowerManager$WakeLock.acquireLocked(PowerManager.java:297)
at android.os.PowerManager$WakeLock.acquire(PowerManager.java:276)
at com.snappext.Backup.AlarmReceiver.onReceive(AlarmReceiver.java:54)
at android.app.ActivityThread.handleReceiver(ActivityThread.java:2133)
at android.app.ActivityThread.access00(ActivityThread.java:127)
at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1211)
at android.os.Handler.dispatchMessage(Handler.java:99)
at android.os.Looper.loop(Looper.java:137)
at android.app.ActivityThread.main(ActivityThread.java:4512)
at java.lang.reflect.Method.invokeNative(Native Method)
at java.lang.reflect.Method.invoke(Method.java:511)
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:982)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:749)
at dalvik.system.NativeStart.main(Native Method)
有线索吗?
Android 权限区分大小写。改用这个:
<uses-permission android:name="android.permission.WAKE_LOCK"/>
尝试将权限更改为
<uses-permission android:name="android.permission.WAKE_LOCK" />
我假设大写字母在这里有所不同,但我可能错了。
参考:https://developer.android.com/training/scheduling/wakelock.html
我正在开发一个本机 android 应用程序,每 30 分钟 运行 一些操作。 我需要确保处理器是 运行ning,所以我使用了
PowerManager.Wakelock 报警接收器内。
这是我在内部用于警报接收器的代码。
public class AlarmReceiver extends BroadcastReceiver {
@Override
public void onReceive(Context context, Intent arg1) {
PowerManager pm = (PowerManager) context.getSystemService(context.POWER_SERVICE);
PowerManager.WakeLock wl = pm.newWakeLock(PowerManager.PARTIAL_WAKE_LOCK, "My Tag");
wl.acquire();
Intent eventService = new Intent(context, SyncInBackground.class);
context.startService(eventService);
wl.release();
}
}
并且在我的主要 AndroidManifest.xml
我添加了以下行来请求权限
<uses-permission android:name="android.permission.wake_lock"/>
当我在应用程序中 运行 发出警报时,出现以下异常
02-07 23:25:02.839 13699-13699/com.snappext E/AndroidRuntime﹕ FATAL EXCEPTION: main
java.lang.RuntimeException: Unable to start receiver com.snappext.Backup.AlarmReceiver: java.lang.SecurityException: Neither user 10008 nor current process has android.permission.WAKE_LOCK.
at android.app.ActivityThread.handleReceiver(ActivityThread.java:2140)
at android.app.ActivityThread.access00(ActivityThread.java:127)
at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1211)
at android.os.Handler.dispatchMessage(Handler.java:99)
at android.os.Looper.loop(Looper.java:137)
at android.app.ActivityThread.main(ActivityThread.java:4512)
at java.lang.reflect.Method.invokeNative(Native Method)
at java.lang.reflect.Method.invoke(Method.java:511)
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:982)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:749)
at dalvik.system.NativeStart.main(Native Method)
Caused by: java.lang.SecurityException: Neither user 10008 nor current process has android.permission.WAKE_LOCK.
at android.os.Parcel.readException(Parcel.java:1327)
at android.os.Parcel.readException(Parcel.java:1281)
at android.os.IPowerManager$Stub$Proxy.acquireWakeLock(IPowerManager.java:381)
at android.os.PowerManager$WakeLock.acquireLocked(PowerManager.java:297)
at android.os.PowerManager$WakeLock.acquire(PowerManager.java:276)
at com.snappext.Backup.AlarmReceiver.onReceive(AlarmReceiver.java:54)
at android.app.ActivityThread.handleReceiver(ActivityThread.java:2133)
at android.app.ActivityThread.access00(ActivityThread.java:127)
at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1211)
at android.os.Handler.dispatchMessage(Handler.java:99)
at android.os.Looper.loop(Looper.java:137)
at android.app.ActivityThread.main(ActivityThread.java:4512)
at java.lang.reflect.Method.invokeNative(Native Method)
at java.lang.reflect.Method.invoke(Method.java:511)
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:982)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:749)
at dalvik.system.NativeStart.main(Native Method)
有线索吗?
Android 权限区分大小写。改用这个:
<uses-permission android:name="android.permission.WAKE_LOCK"/>
尝试将权限更改为
<uses-permission android:name="android.permission.WAKE_LOCK" />
我假设大写字母在这里有所不同,但我可能错了。
参考:https://developer.android.com/training/scheduling/wakelock.html