Android静默安装

本文介绍了两种在Android设备上实现静默安装APK的方法。一种是通过命令行方式使用pminstall命令并确保拥有相应的执行权限;另一种是通过系统调用的方式,利用PackageInstaller组件提供的API进行静默安装。
摘要由CSDN通过智能技术生成

方法一:命令行方式

想要做到静默安装,其实就是要有权限执行pm install命令。准备工作其实就两步:

1、获取执行权限
2、执行命令

我们首先介绍第二步,如何执行pm install命令:
关键代码其实就一句:

Runtime.getRuntime().exec("pm install xxx.apk");

网上也有人提到利用BufferReader读取控制台的输出Success来判断是否安装成功,但我始终没有抓到最后输出的那一句Success,只好用Package install的receiver来处理安装成功后的操作。

再回到如何获取权限的方法,

1、首先,我们要做的就是从Android的系统源码的/build/target/product/security目录中,找到两个签名文件: platform.x509.pem和platform.pk8

2、在/build/tools/signapk目录下找到signapk.jar文件的源码,编译成signapk.jar文件

3、然后在Android项目的manifest.xml文件中,加上INSTALL_PACKAGES的权限。

4、导出apk文件,这里选择签名文件导出。右键项目->"Android Tools"->"Export Signed application Package..."

5、最后就是执行
jar signapk.jar platform.x509.pem platform.pk8 签名的apk  目标文件.apk

由此生成的目标文件apk就可以正常安装在Android中,并可以静默安装任意指定的apk文件了。

转自:http://bbs.51cto.com/thread-968264-1.html

方法二:系统调用

通常情况下,android是没有提供静默方式的上层接口,我们需要在android源代码下来调用这个隐藏的接口来完成静默安装。
最重要的就是参考android系统目录下的packages/apps/PackageInstaller,
当中有两个文件 PackageInstallerActivity.java,InstallAppProgress.java ,前者就是我们通常看到的带有提示对话框的安装应用程序,后者是点确定安装后调用的intent。
现提供一个静默安装的关键类,该类在android2.2下成功编译, 其中通过循环调用接口instatllBatch则可实现批量安装
当然最后的应用程序别忘记添加权限

[html]  view plain copy
  1. <uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE"/>  
  2.     <uses-permission android:name="android.permission.INSTALL_PACKAGES" />  
  3.     <uses-permission android:name="android.permission.DELETE_PACKAGES" />  
  4.     <uses-permission android:name="android.permission.CLEAR_APP_CACHE" />  
  5.     <uses-permission android:name="android.permission.READ_PHONE_STATE" />  
  6.     <uses-permission android:name="android.permission.CLEAR_APP_USER_DATA" />  

[java]  view plain copy
  1. package com.android.util;  
  2.   
  3. import java.io.File;    
  4.   
  5. import java.io.FileNotFoundException;    
  6.   
  7. import java.io.FileOutputStream;    
  8.   
  9. import java.io.IOException;    
  10.   
  11. import android.content.Context;    
  12.   
  13. import android.content.Intent;    
  14.   
  15. import android.content.pm.PackageInfo;    
  16.   
  17. import android.content.pm.PackageManager;    
  18.   
  19. import android.content.pm.PackageManager.NameNotFoundException;    
  20.   
  21. import android.content.pm.ApplicationInfo;  
  22.   
  23. import android.content.pm.PackageParser;  
  24.   
  25. import android.net.Uri;    
  26.   
  27. import android.util.Log;    
  28.   
  29. import android.util.DisplayMetrics;  
  30.   
  31. import android.content.pm.IPackageInstallObserver;    
  32.   
  33. import android.content.pm.IPackageDeleteObserver;    
  34.   
  35. import android.os.FileUtils;    
  36.   
  37. import android.os.Handler;  
  38.   
  39. import android.os.Message;  
  40.   
  41.    
  42.   
  43. public class PackageInstaller {    
  44.   
  45.    
  46.   
  47. private File mTmpFile;    
  48.   
  49. private final int INSTALL_COMPLETE = 1;  
  50.   
  51. final static int SUCCEEDED = 1;  
  52.   
  53. final static int FAILED = 0;  
  54.   
  55. private final static String TAG = "PackInstaller";    
  56.   
  57. private Context mContext;    
  58.   
  59. private ApplicationInfo mAppInfo;  
  60.   
  61. public PackageInstaller(Context context) {    
  62.   
  63. mContext = context;    
  64.   
  65. }    
  66.   
  67. public void install(String path,String packageName){    
  68.   
  69. Intent intent = new Intent(Intent.ACTION_VIEW);    
  70.   
  71. intent.setDataAndType(Uri.fromFile(new File(path)),    
  72.   
  73. "application/vnd.android.package-archive");    
  74.   
  75. mContext.startActivity(intent);    
  76.   
  77. }    
  78.   
  79.    
  80.   
  81. public void instatllBatch(String path) {    
  82.   
  83. Log.i(TAG, "path=" + path);    
  84.   
  85. int installFlags = 0;    
  86.   
  87. Uri mPackageURI  = Uri.fromFile(new File(path));  
  88.   
  89. PackageParser.Package mPkgInfo = getPackageInfo(mPackageURI);  
  90.   
  91. mAppInfo =  mPkgInfo.applicationInfo;  
  92.   
  93. String packageName = mAppInfo.packageName;  
  94.   
  95. Log.i(TAG, "====install packageName ="+packageName);  
  96.   
  97. PackageManager pm = mContext.getPackageManager();    
  98.   
  99. try {    
  100.   
  101. PackageInfo pi = pm.getPackageInfo(packageName,    
  102.   
  103. PackageManager.GET_UNINSTALLED_PACKAGES);    
  104.   
  105. if (pi != null) {    
  106.   
  107. installFlags |= PackageManager.INSTALL_REPLACE_EXISTING;    
  108.   
  109. }    
  110.   
  111. catch (NameNotFoundException e) {    
  112.   
  113. }    
  114.   
  115. if ((installFlags & PackageManager.INSTALL_REPLACE_EXISTING) != 0) {    
  116.   
  117. Log.w(TAG, "Replacing package:" + packageName);    
  118.   
  119. }    
  120.   
  121.    
  122.   
  123. PackageInstallObserver observer = new PackageInstallObserver();    
  124.   
  125. pm.installPackage(mPackageURI, observer, installFlags,    
  126.   
  127. packageName);    
  128.   
  129. }    
  130.   
  131. private class PackageInstallObserver extends IPackageInstallObserver.Stub {    
  132.   
  133. public void packageInstalled(String packageName, int returnCode) {    
  134.   
  135. // Message msg = mHandler.obtainMessage(INSTALL_COMPLETE);    
  136.   
  137. // msg.arg1 = returnCode;    
  138.   
  139. // mHandler.sendMessage(msg);    
  140.   
  141. Log.i(TAG, "====INSTALL_COMPLETE");    
  142.   
  143. }    
  144.   
  145. }    
  146.   
  147. private class PackageDeleteObserver extends IPackageDeleteObserver.Stub {    
  148.   
  149. public void packageDeleted(boolean succeeded) {    
  150.   
  151. //            Message msg = mHandler.obtainMessage(UNINSTALL_COMPLETE);    
  152.   
  153. //            msg.arg1 = succeeded?SUCCEEDED:FAILED;    
  154.   
  155. //            mHandler.sendMessage(msg);    
  156.   
  157. Log.i(TAG, "====UNINSTALL_COMPLETE");    
  158.   
  159. }    
  160.   
  161. }    
  162.   
  163.     public void uninstall(String packageName){    
  164.   
  165. Uri packageURI = Uri.parse("package:" + packageName);    
  166.   
  167. Intent uninstallIntent = new Intent(Intent.ACTION_DELETE,    
  168.   
  169. packageURI);    
  170.   
  171. mContext.startActivity(uninstallIntent);    
  172.   
  173. }    
  174.   
  175.    
  176.   
  177. public void uninstallBatch(String packageName) {    
  178.   
  179. PackageDeleteObserver observer = new PackageDeleteObserver();    
  180.   
  181. mContext.getPackageManager().deletePackage(packageName, observer, 0);    
  182.   
  183.    
  184.   
  185. }    
  186.   
  187. /*   
  188.  
  189. *  Utility method to get package information for a given packageURI            
  190.  
  191. */  
  192.   
  193. public  PackageParser.Package getPackageInfo(Uri packageURI) {  
  194.   
  195. final String archiveFilePath = packageURI.getPath();  
  196.   
  197. PackageParser packageParser = new PackageParser(archiveFilePath);  
  198.   
  199. File sourceFile = new File(archiveFilePath);  
  200.   
  201. DisplayMetrics metrics = new DisplayMetrics();  
  202.   
  203. metrics.setToDefaults();  
  204.   
  205. PackageParser.Package pkg =  packageParser.parsePackage(sourceFile,  
  206.   
  207. archiveFilePath, metrics, 0);   
  208.   
  209. // Nuke the parser reference.  
  210.   
  211. packageParser = null;  
  212.   
  213. return pkg;  
  214.   
  215. }  
  216.   
  217. /* 
  218.  
  219. * Utility method to get application information for a given packageURI 
  220.  
  221. */  
  222.   
  223. public   ApplicationInfo getApplicationInfo(Uri packageURI) {  
  224.   
  225. final String archiveFilePath = packageURI.getPath();  
  226.   
  227. PackageParser packageParser = new PackageParser(archiveFilePath);  
  228.   
  229. File sourceFile = new File(archiveFilePath);  
  230.   
  231. DisplayMetrics metrics = new DisplayMetrics();  
  232.   
  233. metrics.setToDefaults();  
  234.   
  235. PackageParser.Package pkg = packageParser.parsePackage(sourceFile, archiveFilePath, metrics, 0);  
  236.   
  237. if (pkg == null) {  
  238.   
  239. return null;  
  240.   
  241. }  
  242.   
  243. return pkg.applicationInfo;  
  244.   
  245. }  
  246.   
  247. private Handler mHandler = new Handler() {  
  248.   
  249. public void handleMessage(Message msg) {  
  250.   
  251. switch (msg.what) {  
  252.   
  253. case INSTALL_COMPLETE:  
  254.   
  255. if(msg.arg1 == SUCCEEDED) {  
  256.   
  257.    
  258.   
  259. else {}  
  260.   
  261. break;  
  262.   
  263. default:  
  264.   
  265. break;  
  266.   
  267. }  
  268.   
  269. }  
  270.   
  271. };  
  272.   
  273. }  

转自:http://www.open-open.com/lib/view/open1328536451483.html
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值