startBluetoothSco () создает исключение безопасности (BROADCAST_STICKY) для ICS - PullRequest
7 голосов
/ 30 декабря 2011

У меня есть трассировка стека, отправленная пользователем с ICS.

На моем устройстве Froyo все работает нормально, но пользователь, по-видимому, получает Отказ в разрешении при вызове AudioManager.startBluetoothSco() ... Я понятия не имею, почему это происходит - я знаю, что Broadcast for 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 или нет.

1 Ответ

4 голосов
/ 04 мая 2012

Единственный обходной путь - добавить это разрешение в ваше приложение, чтобы оно работало на ICS.

<uses-permission android:name="android.permission.BROADCAST_STICKY"/>

Существует проблема, зарегистрированная здесь, на OHAP для этого дефекта в ICS

...