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

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

第一个方法简单点,不过需要在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运行在一个进程中,这样可以共享数据,应该会很有用的。

以上部分来自: http://blog.csdn.net/liujian885/archive/2010/03/22/5404834.aspx

应用调试注解:

1. signapk.jar:signapk可执行文件,在out/host/linux-x86/framework/signapk.jar;

2. signapk用法:到out/host/linux-x86/framework/目录下执行

java -jar ./signapk platform.x509.pem platform.pk8 input.apk output.apk;

3. 在build/target/product/security/下有platform、shared、testkey、media四个密钥,经验证,如不用android.uid.system, 应采用shared key,如android.uid.phone;

4. 据网友验证,不需要删掉META-INF目录下的CERT.SF和CERT.RSA两个文件,直接signapk就可以。

  如:http://hi.baidu.com/donghaozheng/blog/item/30a00d4f9fca873baec3ab69.html

更多相关文章

  1. android 5.1.1开机优化(framework层)
  2. Android(安卓)美化之Toolbar控件使用
  3. 安装Android(安卓)2.2 SDK时出现的问题
  4. Android(安卓)adb push ... Read-only file system
  5. android创建文件夹和文件
  6. Android对文件的操作(简单的文件读取与写入)
  7. 内核直接NFS挂载Android文件系统启动
  8. (原创)Android入门教程(三十六)------实现手机联系人的全选
  9. Android图片浏览器之缩略图

随机推荐

  1. mysql5.7 生成列 generated column用法实
  2. mysql8 公用表表达式CTE的使用方法实例分
  3. mysql中left join设置条件在on与where时
  4. mysql5.7 新增的json字段类型用法实例分
  5. mysql中各种常见join连表查询实例总结
  6. mysql 主从数据不一致,提示: Slave_SQL_Ru
  7. mysql 中 replace into 与 insert into o
  8. 解决MySQL server has gone away错误的方
  9. centos7环境下创建mysql5.6多实例的方法
  10. centos7环境下二进制安装包安装 mysql5.6