我的编程空间,编程开发者的网络收藏夹
学习永远不晚

Android5.1系统如何通过包名给应用开放系统权限

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

Android5.1系统如何通过包名给应用开放系统权限

这篇文章主要介绍了Android5.1系统如何通过包名给应用开放系统权限,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。

常用的给应用开放系统权限的方法是直接将该应用做成系统应用(即在AndroidManifest.xml文件里加上:android:sharedUserId="android.uid.system"),但是这种做法限制了应用本身的自由,也就是说经过系统签名后的系统应用只能够在对应的Android平台上安装使用,无法向其他应用一样放到Android市场里兼容所有的Android设备。

    现在此介绍一种通过修改Android平台系统层代码,根据指定的应用包名给对应的应用在该平台上开放系统权限,这样既不应用应用的兼容性,又解决了应用想调用一些系统层接口而没有权限的矛盾。

    该方法的核心是:在ActivityManagerService的startProcessLocked接口中把uid和gid都改为0.

需要开放系统权限的包名:

net.forclass.fcstudent

com.ckl.launcher

com.creative.fcstudent

修改步骤:

应用安装在设备上之后,点击启动必定会调用ActivityManagerService的startProcessLocked接口来开启一个新的进程,而给应用开放系统权限目的其实就是使应用能够成为超级应用,运行在系统进程中,这样我们只需要在startProcessLocked接口里面将应用的uid修改为0即可。

ActivityManagerService.java (frameworks\base\services\core\java\com\android\server\am)  final ProcessRecord startProcessLocked(String processName, ApplicationInfo info,      boolean knownToBeDead, int intentFlags, String hostingType, ComponentName hostingName,      boolean allowWhileBooting, boolean isolated, int isolatedUid, boolean keepIfLarge,      String abiOverride, String entryPoint, String[] entryPointArgs, Runnable crashHandler) {    // modified by haming patch begin, configure system permission for some special application.    if ("net.forclass.fcstudent".equals(info.packageName)        || "com.ckl.launcher".equals(info.packageName)        || "com.creative.fcstudent".equals(info.packageName)        || "com.hampoo.hampoointerfacetestdemo".equals(info.packageName)){      info.uid = 0;    }    // modified by haming patch end.    long startTime = SystemClock.elapsedRealtime();    ProcessRecord app;    ...... // 此处省略好多行    checkTime(startTime, "startProcess: stepping in to startProcess");    startProcessLocked( // 再次调用startProcessLocked重载方法        app, hostingType, hostingNameStr, abiOverride, entryPoint, entryPointArgs);    checkTime(startTime, "startProcess: done starting proc!");    return (app.pid != 0) ? app : null;  }在重载方法startProcessLocked(ProcessRecord app, String hostingType,String hostingNameStr, String abiOverride, String entryPoint, String[] entryPointArgs)里面将应用的gid也改为0:  private final void startProcessLocked(ProcessRecord app, String hostingType,      String hostingNameStr, String abiOverride, String entryPoint, String[] entryPointArgs) {    long startTime = SystemClock.elapsedRealtime();    ...... // 此处省略好多行    try {      int uid = app.uid;      int[] gids = null;      int mountExternal = Zygote.MOUNT_EXTERNAL_NONE;      if (!app.isolated) {        ...... // 此处省略好多行        // modified by haming patch begin, configure system permission for some special application.        if ("net.forclass.fcstudent".equals(app.info.packageName)          || "com.ckl.launcher".equals(app.info.packageName)          || "com.creative.fcstudent".equals(app.info.packageName)          || "com.hampoo.hampoointerfacetestdemo".equals(app.info.packageName)){          SystemProperties.set("sys.permission.enable", "true"); // 设置一个系统属性,在Zygote进行判断是否抛出异常          gids[0] = 0;          gids[1] = 0;        } else {          gids[0] = UserHandle.getSharedAppGid(UserHandle.getAppId(uid));          gids[1] = UserHandle.getUserGid(UserHandle.getUserId(uid));        }        // modified by haming patch end.      }      ...... // 此处省略好多行    } catch (RuntimeException e) {      // XXX do better error recovery.      app.setPid(0);      mBatteryStatsService.noteProcessFinish(app.processName, app.info.uid);      if (app.isolated) {        mBatteryStatsService.removeIsolatedUid(app.uid, app.info.uid);      }      Slog.e(TAG, "Failure starting process " + app.processName, e);    }  }

ZygoteConnection.java里的applyUidSecurityPolicy(Arguments args, Credentials peer, String peerSecurityContext)接口会对进程id进行判断,如果小于Process.SYSTEM_UID(1000)则认为是非法,而zygote是具有root权限的唯一server,所有在判断之后就可以通过读取前面设定的系统属性“sys.permission.enable”的值来决定是否抛出异常。

ZygoteConnection.java (frameworks\base\core\java\com\android\internal\os)  private static void applyUidSecurityPolicy(Arguments args, Credentials peer,      String peerSecurityContext)      throws ZygoteSecurityException {    int peerUid = peer.getUid();    if (peerUid == 0) {      // Root can do what it wants    } else if (peerUid == Process.SYSTEM_UID ) {      // System UID is restricted, except in factory test mode      String factoryTest = SystemProperties.get("ro.factorytest");      boolean uidRestricted;            uidRestricted         = !(factoryTest.equals("1") || factoryTest.equals("2"));      // modified by haming patch begin, configure system permission for some special application.      if (uidRestricted          && args.uidSpecified && (args.uid < Process.SYSTEM_UID)) {        if (!SystemProperties.getBoolean("sys.permission.enable", false)){          throw new ZygoteSecurityException(              "System UID may not launch process with UID < "              + Process.SYSTEM_UID);        } else {          SystemProperties.set("sys.permission.enable", "false");        }      }      // modified by haming patch end.    } else {      // Everything else      if (args.uidSpecified || args.gidSpecified        || args.gids != null) {        throw new ZygoteSecurityException(            "App UIDs may not specify uid's or gid's");      }    }    ...... // 此处省略好多行  }

感谢你能够认真阅读完这篇文章,希望小编分享的“Android5.1系统如何通过包名给应用开放系统权限”这篇文章对大家有帮助,同时也希望大家多多支持编程网,关注编程网行业资讯频道,更多相关知识等着你来学习!

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

Android5.1系统如何通过包名给应用开放系统权限

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

Android5.1系统如何通过包名给应用开放系统权限

这篇文章主要介绍了Android5.1系统如何通过包名给应用开放系统权限,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。常用的给应用开放系统权限的方法是直接将该应用做成系统应用
2023-05-30

如何申请云服务器开通权限呢苹果11系统

打开苹果应用商店或其他应用市场,搜索“云服务器”或类似关键词。在搜索结果中选择“云服务器”类别,然后选择“云服务器官网”或“云服务器在线申请”等入口。进入云服务器官网,按照网站的指引进行注册并填写相关信息。在注册过程中,填写邮箱和密码等信息,并选择服务器类型和服务商等信息。在注册完成后,需要选择服务器所在的服务器空间。
如何申请云服务器开通权限呢苹果11系统
2023-10-28

MySQL中如何通过循环构建灵活的权限管理系统

在MySQL中,可以通过使用存储过程和循环来构建灵活的权限管理系统。以下是一个简单的示例代码:创建一个存储过程,该存储过程用于循环创建权限表和用户表:DELIMITER //CREATE PROCEDURE create_permissio
MySQL中如何通过循环构建灵活的权限管理系统
2024-04-30

如何申请云服务器开通权限呢苹果12系统

打开苹果应用商店或其他应用市场,进入“云服务”选项,点击“立即注册”。输入个人信息和云服务器服务提供商的用户名、密码等信息,然后点击“创建新账户”。创建新账户后,在“我的云服务器”页面中,选择“我的服务器”,进入“云服务器管理”页面。在“云服务器管理”页面中,可以查看到您的云服务器状态、配置信息和使用指南等信息。在“云
如何申请云服务器开通权限呢苹果12系统
2023-10-28

编程热搜

  • Python 学习之路 - Python
    一、安装Python34Windows在Python官网(https://www.python.org/downloads/)下载安装包并安装。Python的默认安装路径是:C:\Python34配置环境变量:【右键计算机】--》【属性】-
    Python 学习之路 - Python
  • chatgpt的中文全称是什么
    chatgpt的中文全称是生成型预训练变换模型。ChatGPT是什么ChatGPT是美国人工智能研究实验室OpenAI开发的一种全新聊天机器人模型,它能够通过学习和理解人类的语言来进行对话,还能根据聊天的上下文进行互动,并协助人类完成一系列
    chatgpt的中文全称是什么
  • C/C++中extern函数使用详解
  • C/C++可变参数的使用
    可变参数的使用方法远远不止以下几种,不过在C,C++中使用可变参数时要小心,在使用printf()等函数时传入的参数个数一定不能比前面的格式化字符串中的’%’符号个数少,否则会产生访问越界,运气不好的话还会导致程序崩溃
    C/C++可变参数的使用
  • css样式文件该放在哪里
  • php中数组下标必须是连续的吗
  • Python 3 教程
    Python 3 教程 Python 的 3.0 版本,常被称为 Python 3000,或简称 Py3k。相对于 Python 的早期版本,这是一个较大的升级。为了不带入过多的累赘,Python 3.0 在设计的时候没有考虑向下兼容。 Python
    Python 3 教程
  • Python pip包管理
    一、前言    在Python中, 安装第三方模块是通过 setuptools 这个工具完成的。 Python有两个封装了 setuptools的包管理工具: easy_install  和  pip , 目前官方推荐使用 pip。    
    Python pip包管理
  • ubuntu如何重新编译内核
  • 改善Java代码之慎用java动态编译

目录