1、 Android.mk文件
- LOCAL_PATH:= $(call my-dir)
- include $(CLEAR_VARS)
- LOCAL_MODULE_TAGS := optional
- LOCAL_SRC_FILES := $(call all-subdir-java-files)
- LOCAL_PACKAGE_NAME := PackageInstaller
- LOCAL_CERTIFICATE := platform
- include $(BUILD_PACKAGE)
2、PakcageInstaller.java文件(关键代码)
package cn.ceadic.apkmgr;
import java.io.File;
import java.io.FileNotFoundException;
import java.io.FileOutputStream;
import java.io.IOException;
import android.content.Context;
import android.content.Intent;
import android.content.pm.PackageInfo;
import android.content.pm.PackageManager;
import android.content.pm.PackageManager.NameNotFoundException;
import android.net.Uri;
import android.util.Log;
import android.content.pm.IPackageInstallObserver;
import android.content.pm.IPackageDeleteObserver;
import android.os.FileUtils;
public class PackageInstaller {
private File mTmpFile;
private final String TMP_FILE_NAME = "tmpCopy.apk";
private final static String TAG = "PackInstaller";
private Context mContext;
public PackageInstaller(Context context) {
mContext = context;
}
public void install(String path,String packageName){
Intent intent = new Intent(Intent.ACTION_VIEW);
intent.setDataAndType(Uri.fromFile(new File(path)),
"application/vnd.android.package-archive");
mContext.startActivity(intent);
}
public void instatllBatch(String path, String packageName) {
Log.i(TAG, "path=" + path);
int installFlags = 0;
PackageManager pm = mContext.getPackageManager();
try {
PackageInfo pi = pm.getPackageInfo(packageName,
PackageManager.GET_UNINSTALLED_PACKAGES);
if (pi != null) {
installFlags |= PackageManager.INSTALL_REPLACE_EXISTING;
}
} catch (NameNotFoundException e) {
}
if ((installFlags & PackageManager.INSTALL_REPLACE_EXISTING) != 0) {
Log.w(TAG, "Replacing package:" + packageName);
}
// Create temp file before invoking install api
mTmpFile = createTempPackageFile(path);
if (mTmpFile == null) {
// Message msg = mHandler.obtainMessage(INSTALL_COMPLETE);
// msg.arg1 = PackageManager.INSTALL_FAILED_INSUFFICIENT_STORAGE;
// mHandler.sendMessage(msg);
return;
}
Uri mPackageURI = Uri.parse("file://" + mTmpFile.getPath());
String installerPackageName = mContext.getIntent().getStringExtra(
Intent.EXTRA_INSTALLER_PACKAGE_NAME);
PackageInstallObserver observer = new PackageInstallObserver();
pm.installPackage(mPackageURI, observer, installFlags,
installerPackageName);
}
private File createTempPackageFile(String filePath) {
File tmpPackageFile = mContext.getFileStreamPath(TMP_FILE_NAME);
if (tmpPackageFile == null) {
Log.w(TAG, "Failed to create temp file");
return null;
}
if (tmpPackageFile.exists()) {
tmpPackageFile.delete();
}
// Open file to make it world readable
FileOutputStream fos;
try {
fos = openFileOutput(TMP_FILE_NAME, MODE_WORLD_READABLE);
} catch (FileNotFoundException e1) {
Log.e(TAG, "Error opening file " + TMP_FILE_NAME);
return null;
}
try {
fos.close();
} catch (IOException e) {
Log.e(TAG, "Error opening file " + TMP_FILE_NAME);
return null;
}
File srcPackageFile = new File(filePath);
if (!FileUtils.copyFile(srcPackageFile, tmpPackageFile)) {
Log.w(TAG, "Failed to make copy of file: " + srcPackageFile);
return null;
}
return tmpPackageFile;
}
private class PackageInstallObserver extends IPackageInstallObserver.Stub {
public void packageInstalled(String packageName, int returnCode) {
// Message msg = mHandler.obtainMessage(INSTALL_COMPLETE);
// msg.arg1 = returnCode;
// mHandler.sendMessage(msg);
Log.i(TAG, "====INSTALL_COMPLETE");
}
}
private class PackageDeleteObserver extends IPackageDeleteObserver.Stub {
public void packageDeleted(boolean succeeded) {
// Message msg = mHandler.obtainMessage(UNINSTALL_COMPLETE);
// msg.arg1 = succeeded?SUCCEEDED:FAILED;
// mHandler.sendMessage(msg);
Log.i(TAG, "====UNINSTALL_COMPLETE");
}
}
public void uninstall(String packageName){
Uri packageURI = Uri.parse("package:" + packageName);
Intent uninstallIntent = new Intent(Intent.ACTION_DELETE,
packageURI);
mContext.startActivity(uninstallIntent);
}
public void uninstallBatch(String packageName) {
PackageDeleteObserver observer = new PackageDeleteObserver();
mContext.getPackageManager().deletePackage(packageName, observer, 0);
}
}
3 添加权限.
- <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" />
安装程序的方法:
1、 通过Intent机制,调出系统安装应用,重新安装应用的话,会保留原应用的数据。
String fileName = Environment.getExternalStorageDirectory() + apkName;
Uri uri = Uri.fromFile(new File(fileName));
Intent intent = new Intent(Intent.ACTION_VIEW);
intent.setDataAndType(Uri, application/vnd.android.package-archive");
startActivity(intent);
2、 直接调用安装接口。
Uri mPackageURI = Uri.fromFile(new File(Environment.getExternalStorageDirectory() + apkName));
int installFlags = 0;
PackageManager pm = getPackageManager();
try
{
PackageInfo pi = pm.getPackageInfo(packageName,
PackageManager.GET_UNINSTALLED_PACKAGES);
if(pi != null)
{
installFlags |= PackageManager.REPLACE_EXISTING_PACKAGE;
}
}
catch (NameNotFoundException e)
{}
PackageInstallObserver observer = new PackageInstallObserver();
pm.installPackage(mPackageURI, observer, installFlags);
安装应用权限:android.permission.INSTALL_PACKAGES
系统应用(安装在/system/app下面)可以采用该方式,第三方应用无法申请安装卸载权限。
java.lang.SecurityException: Neither user 10039 nor current process has android.permission.INSTALL_PACKAGES.
3、 执行install命令。
install –r 更新安装,默认新安装;如果不附上-r参数,则会清楚原应用的数据,版本一致则无法安装。
(1)am start …
(2)Runtime.exec(String[] args)
(3)Class<?> execClass = Class.forName("android.os.Exec");
4、 执行cp / adb push命令。
由系统检测到应用程序有更新,自动完成重新安装。
5、 通过第三方软件实现。
Market,EOE,eTrackDog均采用第一种方法实现更新。
优点:由系统核心应用程序控制安装程序;
缺点:无法控制安装过程;安装完成后,也无法立刻启动应用,需要用户确认;无法扩展。
实例:Market查找安装程序
Intent intent =
new Intent(Intent.ACTION_VIEW, Uri.parse("market://search?q=pname:your.app.id"));
startActivity(intent);
卸载程序的方法:
1、 通过Intent机制,调出系统卸载应用。
Uri packageURI = Uri.parse("package: your.app.id");
Intent intent = new Intent(Intent.ACTION_DELETE);
startActivity(intent);
2、 直接调用卸载接口。
PackageInstallObserver observer = new PackageInstallObserver();
pm.installPackage(mPackageURI, observer, installFlags);
卸载应用权限:android.permission.DELETE_PACKAGES
3、 运行rm apk安装文件,由系统检测后调用卸载应用。
相关推荐
5. 清理缓存:删除Android Studio的配置文件夹(Windows默认为%USERPROFILE%.AndroidStudio,Mac默认为~/Library/Preferences/AndroidStudio),然后重新启动。 6. 重装:如果以上方法无效,考虑卸载Android Studio...
在这个项目中,开发者将使用Android Studio创建一个具备基本记事本功能的应用程序,如创建、编辑、删除和查看笔记。 记事本应用通常包含以下核心组件: 1. 用户界面:界面设计需简洁易用,一般包括输入框用于编写...
在Android系统中,将应用程序安装至system/app目录下,使其成为系统级应用,是一项高级操作,主要用于开发者在进行ROM定制、应用预装或是系统级调试时。以下将深入解析这一过程,涵盖技术背景、实现步骤及注意事项。...
本文将详细介绍如何使用"Android系统软件删除工具"以及相关的知识点。 首先,我们要了解的是Android系统的权限机制。由于安全考虑,Android默认不允许用户随意卸载系统应用。为了删除系统应用,你需要获得设备的...
下载并安装后,开发者可以通过这个软件直接在Windows环境下管理Android应用中的SQLite数据库,而无需在设备或模拟器上进行操作,使得调试和测试过程更为便捷。 总的来说,"android SQLite数据库管理软件"是Android...
在这款测试软件中,你可以直接在应用内构造这些请求,无需离开Android设备。 动态添加和删除参数是这个工具的一大亮点。在API测试中,我们常常需要尝试不同的参数组合来检查接口的健壮性。此功能使得这种实验过程变...
在Android平台上,日程管理软件是一种非常实用的应用,它可以帮助用户有效地组织和跟踪日常事务。本文将深入探讨如何创建一个“android日程管理软件”,特别是关于自定义日历界面和SQLite数据库的操作,这对于初学者...
在Android平台上开发一款记事本软件,通常会采用Android Studio作为集成开发环境(IDE)。本文将深入探讨Android Studio的相关知识,以及如何利用它来构建一个功能完善的记事本应用。 一、Android Studio简介 ...
"android文件管理软件源代码"提供了一个实际的案例,可以帮助学习者深入理解如何在Android环境中实现对文件和应用APK的备份与删除功能。下面将详细解释这些知识点。 首先,Android中的文件管理主要涉及以下几个方面...
接下来,需要将系统的软件安装目录从/data/app移动到SD卡的Ext3分区。这涉及到复制、删除原始目录,以及创建软链接。这样,系统会自动将新安装的软件定位到SD卡上,释放手机内存空间。 在完成上述步骤后,手机的...
虚拟机软件安装 在安装 Android 虚拟机之前,需要先安装虚拟机软件,如 VMware、VirtualBox 等。这些软件提供了虚拟机环境,允许用户创建虚拟机并安装操作系统。用户需要下载并安装虚拟机软件,然后创建新的虚拟机...
【Android软件安装在存储卡上】 在Android操作系统中,用户经常面临的一个问题就是手机内存空间不足,尤其是在安装大量应用程序后。Android系统默认情况下会将所有软件安装在内部存储器(通常为ROM)中,这对于内存...
标题中的“数字填图软件Android系统-手机软件”指的是在Android操作系统上运行的,用于数字填图的移动应用程序。这种软件通常被地理信息系统(GIS)专业人员、地图制作者、户外探险者或爱好者使用,它允许用户在数字...
Android 系统删除 Rom 自带软件方法 Android 系统 Rom 自带的软件删除方法是 Android 用户经常遇到的问题。由于 Android 系统不具备卸载 Rom 自带软件的功能,因此用户需要通过其他方式来删除这些软件。在本文中,...
在Android平台上,开发一款账单管理软件涉及到许多关键的技术知识点,包括用户界面设计、数据库管理、数据持久化、日期和时间处理以及数据分析等。这款"Android账单管理软件源码"提供了一个很好的学习平台,让我们...
《Android SQLite Admin 数据库管理软件详解》 在移动应用开发领域,SQLite作为一款轻量级的数据库管理系统,广泛应用于Android平台。它允许开发者在应用程序中存储、管理和检索数据,而无需依赖外部服务器。为了...
在Android操作系统中,管理应用软件是一项重要的功能,它允许用户对设备上的应用程序进行一系列操作,如安装、卸载、更新和组织。这个“android管理应用软件”可能是一个自定义的工具,旨在提供更便捷和全面的控制权...
接下来,在电脑上打开EXE文件,按照安装向导的提示,在手机上完成软件安装。 在卸载安装版软件时,用户可以通过手机的“开始”菜单进入“设置”,然后选择“删除程序”菜单项。在弹出的列表中找到需要删除的软件,...