android应用检测更新

原创 2016年08月29日 17:16:21

序言:

在android开发过程中,我们不可能将一个应用开发到完美才上线(估计永远也无法上线了),所以,我们有版本的更新迭代,放眼安卓应用商店,每一个应用都会有很多个版本,在应用上线并且用户下载安装之后,如果你的应用有新的版本的话,你不可能让每一个用户都重新到应用商店中下载新的版本,所以,我们需要让我们的应用自己检测有没有新的版本。


1. 首先,每一个应用在发布的时候都应该有一个版本,而这个版本需要你自己配置,在android manifest这个文件中,你得指定你应用当前的版本:

<manifest xmlns:android="http://schemas.android.com/apk/res/android

    package="com.jiagj.guanjia"
    android:versionCode="1"
    android:versionName="1.0>
    <application></application>
</manifest>

上面我们看到,表示版本的有两个东西versionCode和VersionName,第一个是一个整数值,表示你的应用更新了多少次,初始值为1,以后每更新一次,该值相应的加1;versionName是你的应用的版本号,这个是String类型的,从1.0开始,然后每次更新你可以指定为新的版本值,可以是1.01、1.02、2.10等等。

2. 然后我们要从服务器拿到这个版本号,也就是versionName,或者是versionCode来和当前你正在使用的应用的版本号进行比较,通过比较可以得知有没有新版本的应用:

从服务器获得版本号通过接口可以获得,获取当前应用的版本如下:

 /**
 * 获取版本号
 *
 * @return 当前应用的版本号
 */
public static String getVersion() {
    try {
        PackageManager manager = RzApplication.getInstance().getPackageManager();
        PackageInfo info = manager.getPackageInfo(RzApplication.getInstance().getPackageName(), 0);
        String version = info.versionName;
        return version;
    } catch (Exception e) {
        e.printStackTrace();
        return null;
    }
}
3. 然后就是下载更新和安装新的apk了,获取新版本的时候,新版本的apk下载地址也需要获取过来,方便我们下载并安装

下载需要在子线程中进行,所以需要新开一个下载文件的线程:

private Handler mHandler = new Handler() {
    public void handleMessage(Message msg) {
        switch (msg.what) {
            // 正在下载
            case DOWNLOAD:
                // 设置进度条位置
                mProgress.setProgress(progress);
                break;
            case DOWNLOAD_FINISH:
                // 安装文件
                installApk();
                break;
            default:
                break;
        }
    }
};

/**
 * 显示软件下载对话框
 */
private void showDownloadDialog() {
    // 构造软件下载对话框
    AlertDialog.Builder builder = new AlertDialog.Builder(mContext);
    builder.setTitle("正在更新");
    // 给下载对话框增加进度条
    final LayoutInflater inflater = LayoutInflater.from(mContext);
    View v = inflater.inflate(R.layout.softupdate_progress, null);
    mProgress = (ProgressBar) v.findViewById(R.id.update_progress);
    builder.setView(v);
    // 取消更新
    builder.setNegativeButton("取消更新", new DialogInterface.OnClickListener() {
        @Override
        public void onClick(DialogInterface dialog, int which) {
            dialog.dismiss();
            // 设置取消状态
            cancelUpdate = true;
        }
    });
    mDownloadDialog = builder.create();
    mDownloadDialog.show();
    // 现在文件
    downloadApk();
}

 /**
 * 下载apk文件
 */
private void downloadApk() {
    // 启动新线程下载软件
    new downloadApkThread().start();
}

/**
 * 下载文件线程
 */
class downloadApkThread extends Thread {
    @Override
    public void run() {
        try {
            // 判断SD卡是否存在,并且是否具有读写权限
            if (Environment.getExternalStorageState().equals(Environment.MEDIA_MOUNTED)) {
                // 获得存储卡的路径
                String sdpath = Environment.getExternalStorageDirectory() + "/";
                mSavePath = sdpath + "download";
                URL url = new URL("新版本apk的url");
                // 创建连接
                HttpURLConnection conn = (HttpURLConnection) url.openConnection();
                conn.connect();
                // 获取文件大小
                int length = conn.getContentLength();
                // 创建输入流
                InputStream is = conn.getInputStream();

                File file = new File(mSavePath);
                // 判断文件目录是否存在
                if (!file.exists()) {
                    file.mkdir();
                }
                File apkFile = new File(mSavePath, "新版本apk的名称");
                FileOutputStream fos = new FileOutputStream(apkFile);
                int count = 0;
                // 缓存
                byte buf[] = new byte[1024];
                // 写入到文件中
                do {
                    int numread = is.read(buf);
                    count += numread;
                    // 计算进度条位置
                    progress = (int) (((float) count / length) * 100);
                    // 更新进度
                    mHandler.sendEmptyMessage(DOWNLOAD);
                    if (numread <= 0) {
                        // 下载完成
                        mHandler.sendEmptyMessage(DOWNLOAD_FINISH);
                        break;
                    }
                    // 写入文件
                    fos.write(buf, 0, numread);
                } while (!cancelUpdate);// 点击取消就停止下载.
                fos.close();
                is.close();
            }
        } catch (MalformedURLException e) {
            e.printStackTrace();
        } catch (IOException e) {
            e.printStackTrace();
        }
        // 取消下载对话框显示
        mDownloadDialog.dismiss();
    }
}

/**
 * 安装APK文件
 */
private void installApk() {
    File apkfile = new File(mSavePath, versionInfo.getName());
    if (!apkfile.exists()) {
        return;
    }
    // 通过Intent安装APK文件
    Intent intent = new Intent(Intent.ACTION_VIEW);
    intent.setDataAndType(Uri.parse("file://" + apkfile.toString()), "application/vnd.android.package-archive");
    mContext.startActivity(intent);
}

上面的代码比较多,我们按照步骤来看:

首先,定义了一个handler来更新下载的状态(正在下载,和下载完成),正在下载的时候通过handler来更新进度条中进度值,下载完成之后,调用安装apk的方法

版权声明:本文为博主原创文章,未经博主允许不得转载。

相关文章推荐

Android应用升级,检测更新,下载,检验,安装

标签: 应用升级大致步骤: 检测是否有更新(读取服务器config文件,比对版本号) 若发现高版本则读取更新文件updateinfo.xml获取下载更新相关信息 ...

检测和解决Android应用的性能问题

开发者在忙碌于构建精美的用户界面或完成新的特性时,很容易忘记性能相关的事情。本文作者就解决Android应用性能问题给出了三个方面,即过度绘制、Android图形渲染以及Memory Leaks内...

Android应用优化之代码检测优化

前言最近换了新的公司,面对新的代码大家都有不同的熟悉过程和方法。在我的角度来说,利用代码检测工具,可以更直接地去熟悉代码逻辑和业务逻辑,表现得自己去代码质量很有追求,最重要当然是在公司的任务管理工时上...

你不知道的Eclipse用法:使用Heap检测和分析Android应用内存

Android Tools中的DDMS带有一个很不错的内存检测工具Heap。使用Heap检测应用进程使用内存情况步骤如下:  在Eclipse中安装和使用Heap步骤  Eclipse安...

基于SVM的Android应用程序安全检测

0 引言      Android是目前占据全球市场份额第一的智能手机操作系统[1],其智能终端中存储着大量用户的重要信息,如短信、私人和商业联系人、日历数据、照片等等,正受到越来越多的黑客攻击,其...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:深度学习:神经网络中的前向传播和反向传播算法推导
举报原因:
原因补充:

(最多只允许输入30个字)