昨天测试跑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是不允许随便发的;这其实就是个手误,写错了参数,谨以此为戒!
以上只是我解决问题过程中的一点点个人总结,点滴积累,贵在坚持,感谢你的阅览!