Android应用程序更新并下载实例
发布时间 - 2026-01-11 00:26:46 点击率:次整理文档,搜刮出一个Android应用程序更新并下载实例的代码,稍微整理精简一下做下分享。

创建一个新类,名为UpdateManager,代码如下:
import java.io.BufferedReader;
import java.io.File;
import java.io.FileOutputStream;
import java.io.IOException;
import java.io.InputStream;
import java.io.InputStreamReader;
import java.net.HttpURLConnection;
import java.net.MalformedURLException;
import java.net.URL;
import com.af.mobile.R;
import android.app.AlertDialog;
import android.app.Dialog;
import android.app.AlertDialog.Builder;
import android.content.Context;
import android.content.DialogInterface;
import android.content.Intent;
import android.content.DialogInterface.OnClickListener;
import android.content.pm.PackageManager.NameNotFoundException;
import android.net.Uri;
import android.os.Environment;
import android.os.Handler;
import android.os.Message;
import android.view.LayoutInflater;
import android.view.View;
import android.widget.ProgressBar;
import android.widget.Toast;
public class UpdateManager
{private URL url=null;
/* 下载中 */
private static final int DOWNLOAD = 1;
/* 下载结束 */
private static final int DOWNLOAD_FINISH = 2;
/* 保存解析的XML信息 */
//HashMap<String, String> mHashMap;
/* 下载保存路径 */
private String mSavePath;
/* 记录进度条数量 */
private int progress;
/* 是否取消更新 */
private boolean cancelUpdate = false;
private Context mContext;
/* 更新进度条 */
private ProgressBar mProgress;
private Dialog mDownloadDialog;
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;
}
};
};
public UpdateManager(Context context)
{
this.mContext = context;
}
public void checkUpdate()
{
if (isUpdate())
{
showNoticeDialog();
} else
{
}
}
/**
* 检查软件是否有更新版本
*
* @return
*/
private boolean isUpdate()
{
// 获取当前软件版本
Double versionCode = getVersionCode(mContext);
Double serviceCode = 1.2;
// 版本判断
if (serviceCode > versionCode)
{
return true;
}
return false;
}
// 获取软件版本号
private Double getVersionCode(Context context)
{
Double versionCode = 0.0;
try
{
// 获取软件版本号,对应AndroidManifest.xml下android:versionCode
versionCode = (double) context.getPackageManager().getPackageInfo("com.af.mobile", 0).versionCode;
} catch (NameNotFoundException e)
{
e.printStackTrace();
}
return versionCode;
}
//显示软件更新对话框
private void showNoticeDialog()
{
AlertDialog.Builder builder = new Builder(mContext);
builder.setTitle("软件更新");
String string=download("http://192.168.0.102:9313/daojuserver/uploads/version.xml");//xml的下载地址
builder.setMessage(string);
builder.setPositiveButton("更新", new OnClickListener()
{
@Override
public void onClick(DialogInterface dialog, int which)
{
dialog.dismiss();
// 显示下载对话框
showDownloadDialog();
}
});
// 稍后更新
builder.setNegativeButton("稍后更新", new OnClickListener()
{
@Override
public void onClick(DialogInterface dialog, int which)
{
dialog.dismiss();
}
});
Dialog noticeDialog = builder.create();
noticeDialog.show();
}
// 显示软件下载对话框
private void showDownloadDialog()
{
// 构造软件下载对话框
AlertDialog.Builder builder = new Builder(mContext);
builder.setTitle("djfkjd");//提示信息内容
// 给下载对话框增加进度条
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 OnClickListener()
{
@Override
public void onClick(DialogInterface dialog, int which)
{
dialog.dismiss();
// 设置取消状态
cancelUpdate = true;
}
});
mDownloadDialog = builder.create();
mDownloadDialog.show();
// 现在文件
downloadApk();
}
private void downloadApk()
{
// 启动新线程下载软件
new downloadApkThread().start();
}
private 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("http://192.168.0.102:9313/daojuserver/uploads/SpMobile.apk");//apk下载地址地址
// 创建连接
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, "dhfudh");
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();
}
};
private void installApk()
{
File apkfile = new File(mSavePath, "dhfudh");
if (!apkfile.exists())
{
return;
}
// 通过Intent安装APK文件
Intent i = new Intent(Intent.ACTION_VIEW);
i.setDataAndType(Uri.parse("file://" + apkfile.toString()), "application/vnd.android.package-archive");
mContext.startActivity(i);
}
public String download(String urlString)
{
StringBuffer sbBuffer=new StringBuffer();
String line=null;
BufferedReader buffer=null;
try {
url=new URL(urlString);
HttpURLConnection urlConn=(HttpURLConnection) url.openConnection();
buffer=new BufferedReader(new InputStreamReader(urlConn.getInputStream()));
while((line=buffer.readLine())!=null)
{
sbBuffer.append(line);
}
} catch (Exception e) {
// TODO: handle exception
e.printStackTrace();
}
finally
{
try {
buffer.close();
} catch (Exception e2) {
// TODO: handle exception
e2.printStackTrace();
}
}
return sbBuffer.toString();
}
}
在Android应用程序Main界面
if(isOpenNetwork())//判断是否有网络
{
UpdateManager manager = new UpdateManager(Main.this);
// 检查软件更新
manager.checkUpdate();
}
判断移动端是否有网络
private boolean isOpenNetwork() {
ConnectivityManager connManager = (ConnectivityManager) getSystemService(Context.CONNECTIVITY_SERVICE);
NetworkInfo networkInfo = connManager.getActiveNetworkInfo();
if (networkInfo != null) {
// 2.获取当前网络连接的类型信息
int networkType = networkInfo.getType();
if (ConnectivityManager.TYPE_WIFI == networkType) {
// 当前为wifi网络
} else if (ConnectivityManager.TYPE_MOBILE == networkType) {
// 当前为mobile网络
}
return connManager.getActiveNetworkInfo().isAvailable();
}
return false;
}
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
# android
# 应用更新
# android应用自动更新
# android实现通知栏下载更新app示例
# Android实现检查并下载APK更新、安装APK及获取网络信息的方法
# Android编程实现应用自动更新、下载、安装的方法
# Android程序版本更新之通知栏更新下载安装
# android中DownloadManager实现版本更新
# 监听下载进度实例
# Android中使用AsyncTask实现文件下载以及进度更新提示
# Android 检查更新、下载、安装功能的实现
# Android Studio下载更新Android SDK网络异常或无法下载
# Android SDK Manager更新、下载速度慢问题解决办法
# Android中使用AsyncTask实现下载文件动态更新进度条功能
# Android编程实现下载时主界面与详细界面一致更新的方法
# 对话框
# 进度条
# 软件更新
# 下载地址
# 软件下载
# 稍后
# 应用程序
# 下载软件
# 创建一个
# 存储卡
# 大家多多
# 是否存在
# 判断是否
# 文档
# 软件版本
# false
# mContext
# progress
# boolean
# cancelUpdate
相关栏目:
【
网站优化151355 】
【
网络推广146373 】
【
网络技术251813 】
【
AI营销90571 】
相关推荐:
Linux虚拟化技术教程_KVMQEMU虚拟机安装与调优
如何用腾讯建站主机快速创建免费网站?
免费制作统计图的网站有哪些,如何看待现如今年轻人买房难的情况?
UC浏览器如何切换小说阅读源_UC浏览器阅读源切换【方法】
如何在IIS7上新建站点并设置安全权限?
英语简历制作免费网站推荐,如何将简历翻译成英文?
Python文本处理实践_日志清洗解析【指导】
儿童网站界面设计图片,中国少年儿童教育网站-怎么去注册?
javascript基于原型链的继承及call和apply函数用法分析
如何在腾讯云服务器上快速搭建个人网站?
深圳网站制作培训,深圳哪些招聘网站比较好?
如何自己制作一个网站链接,如何制作一个企业网站,建设网站的基本步骤有哪些?
Claude怎样写结构化提示词_Claude结构化提示词写法【教程】
如何实现javascript表单验证_正则表达式有哪些实用技巧
如何快速查询网站的真实建站时间?
Laravel Docker环境搭建教程_Laravel Sail使用指南
如何挑选优质建站一级代理提升网站排名?
清除minerd进程的简单方法
如何快速搭建高效WAP手机网站吸引移动用户?
微信小程序 input输入框控件详解及实例(多种示例)
如何使用 Go 正则表达式精准提取括号内首个纯字母标识符(忽略数字与嵌套)
如何在 Telegram Web View(iOS)中防止键盘遮挡底部输入框
Python制作简易注册登录系统
Laravel如何实现多语言支持_Laravel本地化与国际化(i18n)配置教程
Laravel怎么配置.env环境变量_Laravel生产环境敏感数据保护与读取【方法】
如何用免费手机建站系统零基础打造专业网站?
Laravel怎么在Controller之外的地方验证数据
php中::能调用final静态方法吗_final修饰静态方法调用规则【解答】
网站页面设计需要考虑到这些问题
Laravel任务队列怎么用_Laravel Queues异步处理任务提升应用性能
Laravel怎么配置不同环境的数据库_Laravel本地测试与生产环境动态切换【方法】
如何快速搭建FTP站点实现文件共享?
百度浏览器如何管理插件 百度浏览器插件管理方法
Laravel的Blade指令怎么自定义_创建你自己的Laravel Blade Directives
如何在Ubuntu系统下快速搭建WordPress个人网站?
Laravel中间件如何使用_Laravel自定义中间件实现权限控制
Laravel怎么配置自定义表前缀_Laravel数据库迁移与Eloquent表名映射【步骤】
软银砸40亿美元收购DigitalBridge 强化AI资料中心布局
浅谈Javascript中的Label语句
如何用花生壳三步快速搭建专属网站?
php结合redis实现高并发下的抢购、秒杀功能的实例
Laravel如何集成微信支付SDK_Laravel使用yansongda-pay实现扫码支付【实战】
EditPlus中的正则表达式 实战(1)
电视网站制作tvbox接口,云海电视怎样自定义添加电视源?
百度输入法ai面板怎么关 百度输入法ai面板隐藏技巧
Python函数文档自动校验_规范解析【教程】
标题:Vue + Vuex 项目中正确使用 JWT 进行身份认证的实践指南
Win11搜索栏无法输入_解决Win11开始菜单搜索没反应问题【技巧】
Laravel如何自定义分页视图?(Pagination示例)
七夕网站制作视频,七夕大促活动怎么报名?

