异常问题not allowed to send broadcast android.intent.action.BATTERY

xiaoxiao2021-02-28  97

昨天测试跑monkey跑出了一个异常,bug发给我之后,先看了一下异常信息,如下:

java.lang.SecurityException: Permission Denial: not allowed to send broadcast android.intent.action.BATTERY_CHANGED from pid=26154, uid=10080     at android.os.Parcel.readException(Parcel.java:1546)     at android.os.Parcel.readException(Parcel.java:1499)     at android.app.ActivityManagerProxy.broadcastIntent(ActivityManagerNative.java:2872)     at android.app.ContextImpl.sendBroadcast(ContextImpl.java:1366)     at android.content.ContextWrapper.sendBroadcast(ContextWrapper.java:377)     at com.bbk.recorder.MainActivity$BatteryLevelReceiver.onReceive(MainActivity.java:1136)     at android.app.LoadedApk$ReceiverDispatcher$Args.run(LoadedApk.java:866)     at android.os.Handler.handleCallback(Handler.java:739)     at android.os.Handler.dispatchMessage(Handler.java:95)     at android.os.Looper.loop(Looper.java:135)     at android.app.ActivityThread.main(ActivityThread.java:5291)     at java.lang.reflect.Method.invoke(Native Method)     at java.lang.reflect.Method.invoke(Method.java:372)     at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:969)     at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:764)

初步分析发现是因为电量变化的广播属于系统广播,非系统应用无权限发送这个广播,为什么会这样呢?细看自己的代码发现:

class BatteryLevelReceiver extends BroadcastReceiver { @Override public void onReceive(Context context, Intent intent) { if (getBatteryLevel() > 0.05) { return; } else { Intent intent1 = new Intent(ACTION_BACKGROUND_RECORD_STATE); intent1.putExtra("key_recording_content",mContentTitle); intent1.putExtra("key_recording_flag",true); MainActivity.this.sendBroadcast(intent);  } }}

在我注册的电量变化广播接收器中,有发送广播的行为,本意是向桌面状态栏发送时间变化的广播 intent1,没想到由于命名的原因,写成了 intent,少写了一个1,intent1是我要发的广播,intent是广播接收器的入参之一,也就是电量变化的intent,这个intent是不允许随便发的;这其实就是个手误,写错了参数,谨以此为戒!

以上只是我解决问题过程中的一点点个人总结,点滴积累,贵在坚持,感谢你的阅览!

转载请注明原文地址: https://www.6miu.com/read-39436.html

最新回复(0)