android实现静默安装与卸载的方法

   2015-06-24 0
核心提示:这篇文章主要介绍了android实现静默安装与卸载的方法,涉及Android权限与命令行操作的相关技巧,需要的朋友可以参考下

本文实例讲述了android实现静默安装与卸载的方法。分享给大家供大家参考。具体如下:

方法1:【使用调用接口方法,由于安装卸载应用程序的部分API是隐藏的,所以必须下载Android系统源码,在源码下开发并编译之后使用MM命令编译生成APK文件】

import java.io.File;
import android.app.Activity;
import android.os.Bundle;
import android.content.Intent;
import android.content.pm.PackageInfo;
import android.content.pm.PackageManager;
import android.content.pm.PackageManager.NameNotFoundException;
import android.content.pm.IPackageInstallObserver;
import android.content.pm.IPackageDeleteObserver;
import android.content.res.Resources;
import android.graphics.drawable.Drawable;
import android.net.Uri;
import android.os.Environment;
import android.os.Handler;
import android.os.Message;
import android.util.Log;
import android.view.View;
import android.view.View.OnClickListener;
import android.widget.Button;
import android.widget.ProgressBar;
import android.widget.TextView;
import android.widget.Toast;
public class InstallActivity extends Activity {
 /** Called when the activity is first created. */
 private String APK_NAME = "QQHD-mini.apk";
 private Button install = null;
 private Button uninstall = null;
 private final int INSTALL_COMPLETE = 1;
 private final int UNINSTALL_COMPLETE = 2;
 final static int SUCCEEDED = 1;
 final static int FAILED = 0;
 public void onCreate(Bundle savedInstanceState) {
  super.onCreate(savedInstanceState);
  setContentView(R.layout.install_uninstall);
  install = (Button) findViewById(R.id.install);
 uninstall = (Button) findViewById(R.id.uninstall);
 uninstall.setOnClickListener(listener1);
  install.setOnClickListener(listener2);
}
 private OnClickListener listener2=new OnClickListener(){
  public void onClick(View v) {
   String fileName = Environment.getExternalStorageDirectory() + "/" + APK_NAME; 
   Uri uri = Uri.fromFile(new File(fileName));
   int installFlags = 0;
   PackageManager pm = getPackageManager();
   try {
    PackageInfo pi = pm.getPackageInfo("com.tencent.minihd.qq", 
      PackageManager.GET_UNINSTALLED_PACKAGES);
    if(pi != null) {
     installFlags |= PackageManager.INSTALL_REPLACE_EXISTING;
    }
   } catch (NameNotFoundException e) {}
   PackageInstallObserver observer = new PackageInstallObserver();
   pm.installPackage(uri, observer, installFlags, "com.tencent.minihd.qq");
  }
 };
 class PackageInstallObserver extends IPackageInstallObserver.Stub {
  public void packageInstalled(String packageName, int returnCode) {
   Message msg = mHandler.obtainMessage(INSTALL_COMPLETE);
   msg.arg1 = returnCode;
   mHandler.sendMessage(msg);
  }
 };
 private Handler mHandler = new Handler() {
  public void handleMessage(Message msg) {
   switch (msg.what) {
    case INSTALL_COMPLETE:
     int centerTextLabel;
     Drawable centerTextDrawable = null;
     if(msg.arg1 == SUCCEEDED) {
      Toast.makeText(getApplicationContext(), "install apk SUCCEEDED", Toast.LENGTH_SHORT).show();
     } else {}
     if (centerTextDrawable != null) {}
     break;
 case UNINSTALL_COMPLETE:
     int centerTextLabel2;
     Drawable centerTextDrawable2 = null;
     if(msg.arg1 == SUCCEEDED) {
      Toast.makeText(getApplicationContext(), "uninstall apk SUCCEEDED", Toast.LENGTH_SHORT).show();
     } else {}
     if (centerTextDrawable2 != null) {}
     break; 
    default:
     break;
   }
  }
 };
 private OnClickListener listener1=new OnClickListener(){
  public void onClick(View v) {
   PackageManager pm = getPackageManager();
   PackageDeleteObserver observer = new PackageDeleteObserver();
   pm.deletePackage("com.tencent.minihd.qq", observer, 0);
  }
 };
 private class PackageDeleteObserver extends IPackageDeleteObserver.Stub {
  public void packageDeleted(String packageName, int returnCode) {
   Message msg = mHandler.obtainMessage(UNINSTALL_COMPLETE);
   msg.arg1 = returnCode;
   mHandler.sendMessage(msg);
  } 
 }
}

安装、卸载相关权限:

<uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE"/>
<uses-permission android:name="android.permission.INSTALL_PACKAGES" />
<uses-permission android:name="android.permission.DELETE_PACKAGES" />
<uses-permission android:name="android.permission.CLEAR_APP_CACHE" />
<uses-permission android:name="android.permission.READ_PHONE_STATE"/>
<uses-permission android:name="android.permission.CLEAR_APP_USER_DATA" />

方法2:【需要获取root权限或者和rom拥有一样的签名,即让该apk以System的身份在系统中运行】

private void test() {
 execCommand("system/bin/pm install -r " + "sdcard/xxx.apk");
 // xxx.apk放置在内置储存的根目录下(mnt/sdcard/xxx.apk)
 // execCommand("system/bin/pm uninstall " + PACKAGE_NAME); 
 //PACKAGE_NAME为xxx.apk包名
 }
 public boolean execCommand(String cmd) {
 Process process = null;
 try {
 process = Runtime.getRuntime().exec(cmd);
 process.waitFor();
 } catch (Exception e) {
 return false;
 } finally {
 try {
 process.destroy();
 } catch (Exception e) {
 }
 }
 return true;
}

其他方法:一些第三方jar包等方式。

希望本文所述对大家的Android程序设计有所帮助。

 
标签: android 安装 卸载
反对 0举报 0 评论 0
 

免责声明:本文仅代表作者个人观点,与乐学笔记(本网)无关。其原创性以及文中陈述文字和内容未经本站证实,对本文以及其中全部或者部分内容、文字的真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
    本网站有部分内容均转载自其它媒体,转载目的在于传递更多信息,并不代表本网赞同其观点和对其真实性负责,若因作品内容、知识产权、版权和其他问题,请及时提供相关证明等材料并与我们留言联系,本网站将在规定时间内给予删除等相关处理.

  • 说一说Android Studio和IDEA中一个很有用的内存调试插件
    说一说Android Studio和IDEA中一个很有用的内存
    JetBrains JVM Debugger Memory View plugin 在我最近的研发活动期间寻找新的工具,以提高我的开发经验,使Android Studio的生活更轻松,我发现一个有用的插件,我从来没有听说过。 这就是为什么,我决定写这个强大的工具,它如何帮助我与内存调试我的应用程
  • 安卓中通知功能的具体实现
    安卓中通知功能的具体实现
    通知[Notification]是Android中比较有特色的功能,当某个应用程序希望给用户发出一些提示信息,而该应用程序又不在前台运行时,就可以借助通知实现。使用通知的步骤1、需要一个NotificationManager来获得NotificationManager manager = (NotificationManager
    02-05 安卓开发
  • Android view系统分析-setContentView
    Android view系统分析-setContentView
    第一天上班,列了一下今年要学习的东西。主要就是深入学习Android相关的系统源代码,夯实基础。对于学习Android系统源代码,也没什么大概,就从我们平常使用最基础的东西学起,也就是从view这个切入点开始学习Android的源码,在没分析源码之前,我们有的时候
    02-05 安卓开发
  • 如何进行网络视频截图/获取视频的缩略图
    如何进行网络视频截图/获取视频的缩略图
    小编导读:获取视频的缩略图,截图正在播放的视频某一帧,是在音视频开发中,常遇到的问题。本文是主要用于点播中截图视频,同时还可以获取点播视频的缩略图进行显示,留下一个问题,如下图所示, 如果要获取直播中节目视频缩略图,该怎么做呢?(ps:直播是直
  • Android NDK 层发起 HTTP 请求的问题及解决
    Android NDK 层发起 HTTP 请求的问题及解决
    前言新的一年,大家新年快乐~~鸡年大吉!本次给大家带来何老师的最新文章~虽然何老师还在过节,但依然放心不下广大开发者,在此佳节还未结束之际,给大家带来最新的技术分享~ 事件的起因不说了,总之是需要实现一个 NDK 层的网络请求。为了多端适用,还是选择
  • SDK热更之如何在SDK代码中自动插桩及如何生成补
    写在前面本文是SDKHotfix相关的SDK热更系列文章中的一篇,以下为项目及系列文章相关链接:SDKHotfix整体介绍:http://blog.bihe0832.com/sdk_hotfix_project.htmlSDKHotfix对应github地址:https://github.com/bihe0832/SDKHoxFix这篇文章主要介绍一下SDK热更
  • 安装量破千万的第一个产品,我总结了3句话
    安装量破千万的第一个产品,我总结了3句话
    在今天的文章中,作者回顾了自己的第一个产品,他说“我做的第一款产品,是我的一块里程碑。”一起来看看~背景老牌大型互联网公司,部门内部创业的一个项目。我作为产品经理,也是第一次做产品经理,主导产品项目。实际上,项目初期包括我和安卓开发2个人。开
  • 移动周刊第 176 期:Android 知识梳理
    移动周刊第 176 期:Android 知识梳理
    写在前面 本期移动周刊第 176 期如约而至,聚焦 Android、iOS、VR/AR/MR、直播等前沿移动开发技术,收录一周最热点,解读开发技巧,每周三移动周刊抢先看,我们希望从中能够让你有一些收获,如果你有好的文章以及优化建议,请发送邮件至mobilehub@csdn.net,
  • Android插件化(六): OpenAtlasの改写aapt以防止资源ID冲突
    Android插件化(六): OpenAtlasの改写aapt以防
    引言Android应用程序的编译中,负责资源打包的是aapt,如果不对打包后的资源ID进行控制,就会导致插件中的资源ID冲突。所以,我们需要改写aapt的源码,以达到通过某种方式传递资源ID的Package ID,通过aapt打包时获取到这个Package ID并且应用才插件资源的命名
    02-05 安卓开发
  • Android架构(一)MVP架构在Android中的实践
    Android架构(一)MVP架构在Android中的实践
    为什么要重视程序的架构设计 对程序进行架构设计的原因,归根结底是为了 提高生产力 。通过设计是程序模块化,做到模块内部的 高聚合 和模块之间的 低耦合 (如依赖注入就是低耦合的集中体现)。 这样做的好处是使得程序开发过程中,开发人员主需要专注于一点,
    02-05 安卓开发
点击排行