<manifest xmlns:android="http://schemas.android.com/apk/res/android"
android:sharedUserId="android.uid.system">
<application android:icon="@drawable/icon" android:label="@string/app_name"
android:allowClearUserData="false" android:process="system"
android:killAfterRestore="false"
>
这样应该可以了,我也是仿照那些不能被杀死的系统应用的AndroidManifest.xml写的,源码环境编译能通过,eclipse没试过

Android中如何修改系统时间(应用程序获得系统权限)

  在android的API中有提供 SystemClock.setCurrentTimeMillis()函数来修改系统时间,可惜无论你怎么调用这个函数都是没用的,无论模拟器还是真机,在logcat中总会得到"Unable to open alarm driver: Permission denied ".这个函数需要root权限或者运行与系统进程中才可以用。

  本来以为就没有办法在应用程序这一层改系统时间了,后来在网上搜了好久,知道这个目的还是可以达到的。

在windows平台通过eclipse编译android源码中,如果编译Settings或者android manifest XML中 shared user id 包含android.uid.shared等系统权限的时候,则会报以下错误。

Installation error: INSTALL_FAILED_UPDATE_INCOMPATIBLE

Installation error: INSTALL_FAILED_SHARED_USER_INCOMPATIBLE


INSTALL_FAILED_UPDATE_INCOMPATIBLE

1、由于卸载没有完全,可以使用设置中卸载相应应用,或者adb uninstall com.android.***


INSTALL_FAILED_SHARED_USER_INCOMPATIBLE

主要是由于使用了android.uid.shared导致的问题。


  第一个方法简单点,不过需要在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 argetproductsecurity",下面的platform.pk8和platform.x509.pem

  两个文件。

  然后用Android提供的Signapk工具来签名,signapk的源代码是

  在"build oolssignapk"下,

  用法为"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运行在一个进程中,这样可以共享数据,应该会很有用的。

更多相关文章

  1. react-native-vector-icons(android)的安装与使用
  2. Android通过串口与PC通信
  3. android webView与js交互
  4. android读取功能
  5. android manifest.xml中元素含义
  6. android 自定义字体
  7. android linux 基础知识总结
  8. Android应用开发相关下载资源
  9. 【Android】Activity知识点

随机推荐

  1. Android列表控件Spinner简单用法示例
  2. How to Use Android(安卓)Downloads Prov
  3. Android(安卓)OpenGL学习笔记(二)之----
  4. android httpclient localhost Connectio
  5. Android(安卓)LBS系列04 位置和地图服务
  6. Android中文API (110) —— CursorTreeAd
  7. Android中Adapter类详解
  8. Android参数设置: Preference
  9. WebKit android介绍
  10. Android开发学习 之 一、开发环境的搭建