zoukankan      html  css  js  c++  java
  • Android权限不够问题

    很多应用程序在调用Runtime.exec的时候或者创建服务的时候都会遇到权限不够的情况。可采用以下解决方案:

    AndroidManifest.xml:

    <manifest xmlns:android="http://schemas.android.com/apk/res/android"
    package="com.mokoid.LedTest"
    android:sharedUserId="android.uid.system">

    原来,ServiceManager 会去检查应用的权限,Android系统会根据User ID做权限管理,在frmeworks/base/cmds/servicemanager/service_manager.c 里有如下代码:

    int svc_can_register(unsigned uid, uint16_t *name)

    修改 allowed数组即可

    如果在应用层出现问题,则需要涉及到权限管理的两个文件:AndroidManifest.xml 和 Android.mk

    AndroidManifest.xml
    声明权限:
    <uses-permission android:name="android.permission.ACCESS_SURFACE_FLINGER" />
    <uses-permission android:name="android.permission.VIBRATE"/>

    声明用户组     
    <manifest xmlns:android="http://schemas.android.com/apk/res/android"
    package="com.android.inputmethod.pinyin"
    android:sharedUserId="android.uid.system">   

    Android.mk中通过证书来声明权限。
    LOCAL_CERTIFICATE := platform需要和manifest中的android:sharedUserId="android.uid.system" 对应起来。 
    platform 权限问题,最好运行在自己编译的系统上,才可以有特权。如果修改了应用的权限。因为老的应用和数据有关联,因此,重新下载应用并且需要尝试做一个恢复出厂设置或者通过应用管理器删除应用关联的所有数据。 system uid = 1000 是特殊权限进程。

        AID_SYSTEM 被定义为1000,即system server的UID。从上述代码可知,ServiceManager 会去检查应用程序的UID,当UID不符合规定时,便无法执行do_add_service()。也就是,当应用程序的UID不是1000时,没有权限新增Android Service的。所以,在AndroidManifest.xml 里加上 android:sharedUserId 属性的目的在于将应用程序的UID定义为android.uid.system 即1000,程式即可具备Android Service的权限。

        以Mokoid 所提供的范例为例,因为我们是在Android 应用程式中启动Android Service,因此要特別留意这个部分。典型的新增 Android Service 做法是修改 frameworks/base/services/java/com/android/server/SystemServer.java文件,但是需要修改原始的 Android 代码。所以我们可以采用这种做法。

    http://apps.hi.baidu.com/share/detail/33541825

  • 相关阅读:
    Python语言基础04-构造程序逻辑
    Python语言基础03-分支和循环结构
    Python语言基础02-变量和运算
    Python语言基础01-初识Python
    Hadoop+Hbase分布式集群架构“完全篇”
    kubernetes系列12—二个特色的存储卷configmap和secret
    安装AIDE文件完整性检测
    PAM和账户安全配置
    SSH安全配置
    CentOS7的审计配置
  • 原文地址:https://www.cnblogs.com/eustoma/p/2415870.html
Copyright © 2011-2022 走看看