【发布时间】:2012-01-30 12:11:22
【问题描述】:
我有一个使用 ICS 的用户发送的堆栈跟踪。
在我的 Froyo 设备上,一切正常,但是当调用 AudioManager.startBluetoothSco() 时,用户显然得到了 Permission Denial...
我不知道为什么会这样 - 我知道 ACTION_SCO_AUDIO_STATE_CHANGED 的广播 很粘,但发送它的不是应用程序,所以它不需要权限...
下面是堆栈跟踪:
java.lang.SecurityException: Permission Denial: broadcastIntent() requesting a sticky
broadcast from pid=15341, uid=10064 requires android.permission.BROADCAST_STICKY
at android.os.Parcel.readException(Parcel.java:1327)
at android.os.Parcel.readException(Parcel.java:1281)
at android.media.IAudioService$Stub$Proxy.startBluetoothSco(IAudioService.java:1090)
at android.media.AudioManager.startBluetoothSco(AudioManager.java:975)
at de.bulling.smstalk.libs.utils.AudioUtils.startBluetoothSco(AudioUtils.java:164)
at de.bulling.smstalk.Services.TTS.speakIt(TTS.java:151)
at de.bulling.smstalk.Services.TTS.onInit(TTS.java:83)
at android.speech.tts.TextToSpeech.dispatchOnInit(TextToSpeech.java:627)
at android.speech.tts.TextToSpeech.access$1000(TextToSpeech.java:52)
at android.speech.tts.TextToSpeech$Connection.onServiceConnected(TextToSpeech.java:1279)
at android.app.LoadedApk$ServiceDispatcher.doConnected(LoadedApk.java:1068)
at android.app.LoadedApk$ServiceDispatcher$RunConnection.run(LoadedApk.java:1085)
at android.os.Handler.handleCallback(Handler.java:605)
at android.os.Handler.dispatchMessage(Handler.java:92)
at android.os.Looper.loop(Looper.java:137)
at android.app.ActivityThread.main(ActivityThread.java:4424)
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:784)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:551)
at dalvik.system.NativeStart.main(Native Method)
/edit:我可以重现这个问题,不管我是否用START_STICKY启动服务。
【问题讨论】:
-
有什么理由不想包含权限吗?
-
不,我现在将它包含在下一次更新中,但对于此功能应该不需要。所以肯定有什么问题。啊——到目前为止,ICS 带来了很多问题......
-
你能在模拟器中重现它吗?或者它只发生在 Galaxy Nexus 上?可能是特定于设备的问题?
-
我可以使用 4.0.3 模拟器(而不是 4.0)复制它,并且在添加许可的情况下它可以工作。但是权限是用于sending Sticky Intents,而不是用于receiving,所以这可能是 4.0.3 中的错误?
-
我的应用也有同样的问题。新版本的 Android 发生了一些变化。为什么谷歌没有关于更改的信息? =(
标签: android permissions bluetooth