如何修复java.lang.SecurityException:Caller缺少必要的权限com.google.android.things.permission.USE_PERIPHERAL_IO错误?

时间:2018-06-08 02:13:09

标签: java raspberry-pi android-things

我正在尝试在Raspberry Pi 3上构建和运行Android Things项目。找到文件here。我通过以太网连接到我的Raspberry Pi 3。我将以太网电缆直接从笔记本电脑插入rPi并使用了Internet Sharing。然后我使用adb connect连接到设备并成功连接。

我正在跑步:

Android Studio 3.1.2
Build #AI-173.4720617, built on April 13, 2018
JRE: 1.8.0_152-release-1024-b01 x86_64
JVM: OpenJDK 64-Bit Server VM by JetBrains s.r.o
Mac OS X 10.12.6

对Android Studio进行了更改,因此我不得不更改一些代码。我下载了这些文件,并将PeripheralManagerService更新为PeripheralManager

PeripheralManager pioService = PeripheralManager.getInstance();

当我单击“运行”按钮时,出现以下错误(请记住,我已将以下权限添加到应用程序部分上方的Android Manifest文件中):

<uses-permission android:name="com.google.android.things.permission.USE_PERIPHERAL_IO"/>

请帮我弄清楚我还缺少什么。谢谢!

06-08 01:43:28.746 3598-3598/? I/zygote: Late-enabling -Xcheck:jni 06-08 01:43:28.993 3598-3598/apps.hackstermia.buttonthings I/MainActivity: Starting ButtonActivity
06-08 01:43:29.013 3598-3598/apps.hackstermia.buttonthings I/MainActivity: Configuring GPIO pins
06-08 01:43:29.017 3598-3598/apps.hackstermia.buttonthings D/AndroidRuntime: Shutting down VM
06-08 01:43:29.028 3598-3598/apps.hackstermia.buttonthings E/AndroidRuntime: FATAL EXCEPTION: main
    Process: apps.hackstermia.buttonthings, PID: 3598
    java.lang.RuntimeException: Unable to start activity ComponentInfo{apps.hackstermia.buttonthings/apps.hackstermia.buttonthings.MainActivity}: java.lang.SecurityException: Caller lacks required permission com.google.android.things.permission.USE_PERIPHERAL_IO
        at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2778)
        at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2856)
        at android.app.ActivityThread.-wrap11(Unknown Source:0)
        at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1589)
        at android.os.Handler.dispatchMessage(Handler.java:106)
        at android.os.Looper.loop(Looper.java:164)
        at android.app.ActivityThread.main(ActivityThread.java:6494)
        at java.lang.reflect.Method.invoke(Native Method)
        at com.android.internal.os.RuntimeInit$MethodAndArgsCaller.run(RuntimeInit.java:438)
        at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:807)
     Caused by: java.lang.SecurityException: Caller lacks required permission com.google.android.things.permission.USE_PERIPHERAL_IO
        at android.os.Parcel.readException(Parcel.java:2005)
        at android.os.Parcel.readException(Parcel.java:1951)
        at com.google.android.things.pio.IPeripheralManagerClient$Stub$Proxy.GetGpioClient(IPeripheralManagerClient.java:759)
        at com.google.android.things.pio.GpioImpl.<init>(GpioImpl.java:50)
        at com.google.android.things.pio.PeripheralManager.openGpio(PeripheralManager.java:197)
        at apps.hackstermia.buttonthings.MainActivity.onCreate(MainActivity.java:26)
        at android.app.Activity.performCreate(Activity.java:7010)
        at android.app.Activity.performCreate(Activity.java:7001)
        at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1214)
        at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2731)
        at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2856) 
        at android.app.ActivityThread.-wrap11(Unknown Source:0) 
        at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1589) 
        at android.os.Handler.dispatchMessage(Handler.java:106) 
        at android.os.Looper.loop(Looper.java:164) 
        at android.app.ActivityThread.main(ActivityThread.java:6494) 
        at java.lang.reflect.Method.invoke(Native Method) 
        at com.android.internal.os.RuntimeInit$MethodAndArgsCaller.run(RuntimeInit.java:438) 
        at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:807) 
06-08 01:43:29.047 3598-3598/apps.hackstermia.buttonthings I/Process: Sending signal. PID: 3598 SIG: 9

5 个答案:

答案 0 :(得分:1)

啦〜!

我的Android Studio 3.1.3和RaspberryPi 3以及AndroidThings也遇到了同样的问题。这个平台正在杀死我的“眨眼”应用程序,因为我没有“[..] USE_PERIPHERAL_IO”的许可。

对于我的问题,解决方案是添加这句话:

<uses-permission android:name="com.google.android.things.permission.USE_PERIPHERAL_IO"/>
<uses-permission android:name="com.google.android.things.permission.MANAGE_INPUT_DRIVERS" />

到我的Android Manifest文件。

谢谢,任何人都可以寻求帮助:))

答案 1 :(得分:1)

首先,AndroidManifest应该在application tag

之前加入以下几行
<uses-permission android:name="com.google.android.things.permission.USE_PERIPHERAL_IO" />
<uses-permission android:name="com.google.android.things.permission.MANAGE_INPUT_DRIVERS" />

然后,如果您通过adb安装应用程序,则应按照{@ 1evunwired here

的建议,通过<APK>选项安装-g
adb install -g <APK>

答案 2 :(得分:0)

根据Android Studio的版本,监狱在升级和安装时应用并授予,或仅在安装时使用(​​旧版本)

重新启动设备应该修复它,卸载并重新安装应用程序也应修复它。

答案 3 :(得分:0)

感谢大家的投入。

我发现清单文件中的权限需要是直接子项,或者在应用程序之外

答案 4 :(得分:0)

我有同样的问题。尝试了如上所述的不同方法。什么对我有用 1.将您的android工作室更新到最新版本。我的是3.0.1。升级后,它是3.1.3 2.将最新的android版本的os版本更新。这是0.6。升级后,它是1.0.1。 3.在android清单中设置这些权限 <uses-permission android:name="com.google.android.things.permission.USE_PERIPHERAL_IO"/> <uses-permission android:name="com.google.android.things.permission.MANAGE_INPUT_DRIVERS" />

希望这些步骤能让你的android工作正常工作