android 设置默认浏览器

我们的浏览器要添加的一个功能:设置为默认浏览器,大部分的浏览器都有这个功能,比如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





版权声明:本文为song_shi_chao原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接和本声明。