我们的浏览器要添加的一个功能:设置为默认浏览器,大部分的浏览器都有这个功能,比如UC,百度,360等优秀的产品。
1.http://blog.csdn.net/liws2010/article/details/7452957
2.http://hi.baidu.com/519177819/item/853df8228a8c0c182b0f1cbe
3.http://www.linuxidc.com/Linux/2013-04/82442.htm
4.http://blog.csdn.net/ldinvicible/article/details/8363402
5.http://blog.csdn.net/baolin1389/article/details/6394409
6.http://www.devdiv.com/Android-intent_-thread-122395-1-1.html
7.http://blog.sina.com.cn/s/blog_74c22b210100us1h.html
8.http://hi.baidu.com/kyojfe/item/b2ea8ab72326d2ee4fc7fd84
9.http://www.eoeandroid.com/forum.php?mod=viewthread&tid=54816
10.http://www.eoeandroid.com/forum.php?mod=viewthread&tid=283486
11.http://stackoverflow.com/questions/13167583/clearing-and-setting-the-default-home-application-solved?rq=1
12.http://www.eoeandroid.com/forum.php?mod=viewthread&tid=283486
13.http://stackoverflow.com/questions/3836215/android-change-default-home-application
14.http://stackoverflow.com/questions/2583966/how-do-i-use-packagemanager-addpreferredactivity/3968856#3968856
15.http://stackoverflow.com/questions/3836215/android-change-default-home-application/4649272#4649272
http://hold-on.iteye.com/blog/1827790
最新研究:2013-10-31
一.新发现
1.在android的manifest要添加这个权限:就是设置某个应用为系统默认应用的权限,具体自行查寻。
<uses-permission android:name="android.permission.SET_PREFERRED_APPLICATIONS" />
2. 在应用程序的AndroidManifest.xml中的manifest节点中加入 android:sharedUserId="android.uid.system"这个属性。
3.修改Android.mk文件,加入LOCAL_CERTIFICATE := platform这一行
4. 使用mm命令来编译,生成的apk就有系统权限了。
上面这4个步骤是我之前研究的时候整理的,大家都这么说的,后来发生了一次事故,我发现原来不是这样的。
请注意下面这句话:
如果你的应用之前没有加android:sharedUserId="android.uid.system"这个属性,你突然加了这个属性,然后你会发现,你之前的数据库文件没有了,别的文件,我没注意,反正你的数据库文件肯定是没有了,我觉得你的应用的data目录下的所有数据应该都会被清空了,但是没有验证过哈。后来问了做系统的同事,他解释了一下,我也没太懂:就是当你的应用从普通的用户进程变成系统进程的时候,会检测,发现进程变了,就会清空你的数据。
之前我一直觉得配置这个属性:android:sharedUserId="",比如做一个应用的皮肤的时候,你的皮肤应用和主应用的sharedUserId一样的话,可以互相读取数据,主应用可以读取皮肤apk的数据。原来细细的深究下,android:sharedUserId="",系统本身提供了4个值,具体自行百度查询。
后来没有办法了,我就尝试上面的3个修改,去掉一个留下2个,看是哪个修改造成了浏览器的数据库被清空,发现是
android:sharedUserId="android.uid.system"造成了问题,但是为了获取系统权限,我不加这个能行么?我报着试一试的态度,发现,是可行的。就是说:去掉android:sharedUserId="android.uid.system"这个,只要配置了LOCAL_CERTIFICATE := platform,一样能获取系统权限。
二.新尝试
最近改了编译系统,不用android那套编译系统了,所以没有Android.mk文件这个文件了,那我怎么才能获取系统权限呢?这个让我纠结了,继续查找答案。发现了一个:
http://blog.csdn.net/lili1985516/article/details/7754672
结果,按照上面说的第二个方法去做了,发现是可以的,真的,用那两个证书去签名,真的可以获取系统权限。
注意signapk.jar的执行方式 ,网上看了很多,就下面这个是对的,其它的都不好用,也可能是我用错了:不过这个肯定是可用的,我验证过了。
java -jar signapk.jar xxx.x509.pem xxx.pk8 xxxxx.apk xxxxx-signed.apk (xxx是证书名,xxxxx是所签apk的名字)
下面是上面链接的原文:
第一个方法简单点,不过需要在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.signapk.jar执行方式
java -jar signapk.jar xxx.x509.pem xxx.pk8 xxxxx.apk xxxxx-signed.apk (xxx是证书名,xxxxx是所签apk的名字)
2.相关文件路径
编译后的JAR包位置 android\out\host\linux-x86\framework\signapk.jar
证书文件位置 android\build\target\product\security
signapk.java文件位置 android\build\tools\signapk\SignApk.java
附件为本人修改后的jar包,添加了密码输入,在ant脚本中运行时很有用,呵~
使用方法:
signapk [-w] publickey.x509[.pem] privatekey.pk8 input.jar output.jar passward
参考:
http://blog.csdn.net/hudashi/article/details/7080062
http://blog.csdn.net/hmg25/article/details/6447067
http://blog.csdn.net/vincent_czz/article/details/7199567