有些库的使用条件比较苛刻,要求同一签名的程序才可以获得访问权。此时即便是在AndroidManifest.xml中添加了相应的permission,依旧会得到没有xx访问权限的问题。比如android.permission.ACCESS_SURFACE_FLINGER 。
第一个方法简单点,不过需要在Android系统源码的环境下用make来编译:
1. 在应用程序的AndroidManifest.xml中的manifest节点中加入android:sharedUserId="android.uid.system"这个属性。
2. 修改Android.mk文件,加入LOCAL_CERTIFICATE := platform这一行
3. 使用mm命令来编译,生成的apk就有修改系统时间的权限了。
第二个方法麻烦点,不过不用开虚拟机跑到源码环境下用make来编译:
1. 同上,加入android:sharedUserId="android.uid.system"这个属性。
2. 使用eclipse编译出apk文件,但是这个apk文件是不能用的。
3. 用压缩软件打开apk文件,删掉META-INF目录下的CERT.SF和CERT.RSA两个文件。
4. 使用目标系统的platform密钥来重新给apk文件签名。这步比较麻烦,首先找到密钥文件,在我的Android源码目录中的位置是"build\target\product\security",下面的platform.pk8和platform.x509.pem两个文件。然后用Android提供的Signapk工具来签名,signapk的源代码是在"build\tools\signapk"下,用法为"signapk platform.x509.pem platform.pk8 input.apk output.apk",文件名最好使用绝对路径防止找不到,也可以修改源代码直接使用。
这样最后得到的apk和第一个方法是一样的。
最后解释一下原理,首先加入android:sharedUserId="android.uid.system"这个属性。通过Shared User id,拥有同一个User id的多个APK可以配置成运行在同一个进程中。那么把程序的UID配成android.uid.system,也就是要让程序运行在系统进程中,这样就有权限来修改系统时间了。
只是加入UID还不够,如果这时候安装APK的话发现无法安装,提示签名不符,原因是程序想要运行在系统进程中还要有目标系统的platform. key,就是上面第二个方法提到的platform.pk8和platform.x509.pem两个文件。用这两个key签名后apk才真正可以放入系统进程中。第一个方法中加入LOCAL_CERTIFICATE := platform其实就是用这两个key来签名。
这也有一个问题,就是这样生成的程序只有在原始的Android系统或者是自己编译的系统中才可以用,因为这样的系统才可以拿到platform.pk8和platform.x509.pem两个文件。要是别家公司做的Android上连安装都安装不了。试试原始的Android中的key来签名,程序在模拟器上运行OK,不过放到G3上安装直接提示"Package ... has no signatures that match those in shared user android.uid.system",这样也是保护了系统的安全。
最最后还说下,这个android:sharedUserId属性不只可以把apk放到系统进程中,也可以配置多个APK运行在一个进程中,这样可以共享数据,应该会很有用的。
REF:http://labs.chinamobile.com/go.php?url=http%3A%2F%2Fdev.10086.cn%2Fblog%2F%3Fuid-49302-action-viewspace-itemid-907
转载自:http://blog.csdn.net/jingwen3699/article/details/8024900
相关推荐
用于获取Android程序的系统权限包含文件platform.x509.pem platform.pk8 signapk.jar 经过测试简单,好用
这个工具是android源码里面拿出来的,可以给个人的应用程序进行系统权限的签名
Android开发,获取当前手机安装的所有应用、根据包名获取应用信息、获取当前应用程序的包名、获取程序 图标、获取程序的版本号、获取程序的名字、获取程序的权限、获取程序的签名、获取当前包名的 SHA1、将获取到得...
(一)Android安全架构 Android安全架构中一个中心思想就是:应用程序在默认的情况下不可以执行任何对其他应用程序,系统或者用户带来负面影响的操作... 所有的Android应用程序(.apk文件)必须用数字证书进行签名认证
实现了敏感权限访问记录生成、网络流量和短信的监控、软件行为分析、用户交互模块采用数据报表可视化的方式,让用户直观地了解到手机中各应用程序访问了哪些敏感权限,是否有非授权流量或短信的流出,同时系统还可视...
使用该工具可以将自己的应用程序打包成系统应用,从而获取极大的应用权限,但是仅限于android原生系统
Android 7.0系统在运行应用的时候,对... signature 表示只有当应用程序所用数字签名与声明引权限的应用程序所用数字签名相同时,才能将权限授给它; signatureOrSystem 表示将权限授给具有相同数字签名的应用程序或
Android-Permission-Usage-Without-Defining 使用未定义权限的 Android 签名级权限在这个项目中有两个应用程序。 第一个,名为“first”,使用权限读取联系人并创建后台服务以在被询问时提供联系人列表。 该服务受...
Android 7.0系统在运行应用的时候,对权限做了诸多限制,normal, dangerous, signature, signatureOrSystem ,取决于保护级别,在确定是否授予...signatureOrSystem 表示将权限授给具有相同数字签名的应用程序或android 包
2.5 剖析Android应用程序的结构 2.6 分析Notepad应用程序 2.6.1 加载和运行Notepad应用程序 2.6.2 分解应用程序 2.7 了解应用程序生命周期 2.8 调试应用程序 2.8.1 启动模拟器 2.8.2 ...
解决getRunningAppProcesses只得到本应用的进程的问题,该工具类非常方便,易于理解,不需要获取任何权限。
android 实现自我自动静默卸载 妈妈再也不用担心我是流氓了 部分手机安装失败。本人三星i9108可以 小米安装失败。不知道为什么。同个程序。可能是小米没root,但是代码里面...只是修改了应用权限 把应用系统签名了一下
- 查看已安装和系统应用程序的应用程序权限。 - 列出所有已安装的应用 程序 - 按名称搜索应用程序 -List所有用户应用 程序安装- 显示应用程序名称,版本,更新时间,大小 - 一次卸载多个应用程序 - 各种排序功能,...
Android一键扫描恶意程序包括应用权限的扫描和应用数字特征签名的扫描,通过与病毒数据库的比对,确定Android系统中是否存在恶意程序。
系统软件和本地软件,可以显示软件的详细信息,启动,删除应用程序.连接获取服务器上软件的评分信息等功能。程序锁可以指定要保护的程序, 用户进入要保护的程序之前必须输入密码。 任务管理: 显示当前系统运行的进程...
xml java系统源码 #串口通讯应用 1 串口驱动Java层接口 串口驱动Java层接口调用...编译有系统权限的apk需要提供android系统平台的密钥。密钥文件存储在build/target/product/security/下面的platform.pk8和platform.x50
API级别23和更高版本的更改使正常应用程序无法修改自动旋转设置本博客中介绍的应用程序使用android.permission.WRITE_SETTINGS ,该版本从Android v6.0棉花糖(API级别23)开始,要求该应用程序必须经过系统处理或...
源,包括应用程序名称/标题、图标和Android应用程序的任何其他 资源。 替换图像、编辑/修改Android清单的基本属性,而不必深入其内部 结构。 权限编辑器: 权限编辑器允许您只需单击几下就可以添加或删除Android应用...
对于android系统,安装的第一个应用程序将成为领导者,之后安装的所有应用程序将成为关注者。 您可以从组中的任何应用程序读写数据存储。 所有写操作都转发给领导者,而所有读操作都是本地的。 领导者确保您的数据...