XDUpdate
Android 自动更新 / 阿里云 OSS 一键上传更新
支持 Android 8.1,不会因 FileUriExposedException 而无法安装下载的 APK
JSON、APK、Map 文件的 URL 需要支持外链,即可以被直接访问,可考虑放在 Git 仓库、OSS 或自己的服务器上
引入
build.gradle 中添加
compile 'com.xdandroid:xdupdate:+'
自动更新
1.准备描述更新信息的 JSON 文件
{
"versionCode":4, //新版本的 versionCode,int 型
"versionName":"1.12", //新版本的 versionName,String 型
"url":"http://contoso.com/app.apk", //APK 下载地址,String 型
"note":"Bug 修复", //更新内容,String 型
"md5":"D23788B6A1F95C8B6F7E442D6CA7536C", //32 位 MD5 值,String 型
"size":17962350 //大小(字节),int 型
}
2.构建 XdUpdateAgent 对象
XdUpdateAgent updateAgent = new XdUpdateAgent
.Builder()
.setDebugMode(false) //是否显示调试信息(可选,默认:false)
.setUpdateBean(XdUpdateBean updateBean) //设置通过其他途径得到的 XdUpdateBean(2 选 1)
.setJsonUrl("http://contoso.com/update.json") //JSON 文件的 URL(2 选 1)
.setShowDialogIfWifi(true) //设置在 WiFi 下直接弹出 AlertDialog 而不使用 Notification(可选,默认:false)
.setOnUpdateListener((needUpdate, updateBean) -> {
//取得更新信息 JSON 后的回调(可选),回调在主线程,可执行 UI 操作;
//needUpdate 为是否需要更新,updateBean 为 JSON 对应的数据结构
if (!needUpdate) Toast.makeText(context,"您的应用为最新版本",Toast.LENGTH_SHORT).show();
})
.setDownloadText("立即下载") //可选,默认为左侧所示的文本
.setInstallText("立即安装(已下载)")
.setLaterText("以后再说")
.setHintText("版本更新")
.setDownloadingText("正在下载")
.setIconResId(R.mipmap.ic_launcher) //设置在通知栏显示的通知图标资源 ID(可选,默认为应用图标)
.build();
3.检查更新
updateAgent.update(getActivity());
适用于 App 入口的自动检查更新。默认策略下:
1.若用户选择“以后再说”或者划掉了通知栏的更新提示,则当天对该版本不再提示更新,防止当天每次打开应用时都提示导致用户不胜其烦;
2.在任何网络环境下,均推送一条通知栏更新提示,点击通知后弹出对话框,防止直接弹框带来不好的用户体验。
可调用 XdUpdateAgent.Builder.setShowDialogIfWifi(true) 设置在 WiFi 下直接弹出更新提示框 (AlertDialog) 而不使用 Notification 的形式。
updateAgent.forceUpdate(getActivity());
适用于应用“设置”页面的手动检查更新。此方法无视上面的 2 条默认策略,如果有更新,总是对用户进行提示,且总是使用提示框 (AlertDialog) 的形式。
4.若不想使用 JSON 文件,可传入由其他途径得到的 XdUpdateBean
XdUpdateAgent.Builder.setUpdateBean(XdUpdateBean updateBean);
可使用第三方推送服务的自定义消息/透传功能,接收到服务端推送过来的 JSON(String)后,解析成一个 XdUpdateBean,传入上述方法,即可使用推送带过来的 JSON 进行更新提示。
注意不是普通消息,这样会直接在通知栏上显示内容,不会进到自定义的代码处理块。
阿里云 OSS 一键上传更新
位于/XdUploadClient/下,XdUpdateClient.jar 为程序主体,XdUpdateClient.cmd 为 Windows 下使用的上传脚本,XdUpdateClient.sh 为 Linux 下使用的上传脚本,config.properties 为配置文件,其他文件为源码。
一般使用只需把上述 4 个文件放到一个目录(下面称为工作目录)下即可。
1.将更新过的 APK 命名为 (包名).apk,放到工作目录下
2.编辑 config.properties 配置文件
packageName = com.xdandroid.myproject //包名
releaseNote = Bug 修复 //更新内容
cdnDomain = http://my-project.oss-cn-shenzhen.aliyuncs.com/ //文件 URL 的主机名部分(斜线后置)
endpoint = http://oss-cn-shenzhen.aliyuncs.com //OSS 的 Endpoint(无斜线)
accessKeyId = xXxxxXxXxxXxxxxX //OSS 的 AccessKeyId
accessKeySecret = xXxxxxxXXxxXxxxXxxXxxXXXXxxXxx //OSS 的 AccessKeySecret
bucketName = my-project //OSS 的 BucketName
pathPrefix = download/ //文件 URL 的路径部分(不含文件名, 斜线后置)
上传后的 APK 安装包的 URL 为 : cdnDomain + pathPrefix + packageName + ".apk"
上传后的 JSON 文件的 URL 为 : cdnDomain + pathPrefix + packageName + ".json"
3.将 JSON 文件的 URL 填入 XdUpdateAgent.Builder 的 setJsonUrl(String jsonUrl)
4.运行 XdUpdateClient.cmd/XdUpdateClient.sh,等待上传完成
Linux 系统下,XdUpdateClient.sh 需具有"可执行"文件系统权限。
5.指定使用的配置文件(可选)
运行 XdUpdateClient.jar 时可以带一个参数,传入配置文件的路径,即可使用该配置文件,而不是默认的 config.properties。
java -jar XdUploadClient.jar my-project.properties
若不带参数运行 XdUpdateClient.jar,将使用与 XdUpdateClient.jar 同目录下的 config.properties。