XDUpdate

Introduction: Android 自动更新 / 阿里云 OSS 一键上传更新 (Android auto update / upload update by aliyun OSS)
More: Author   ReportBugs   
Tags:
Update-

Android 自动更新 / 阿里云 OSS 一键上传更新

  • 支持 Android 8.1,不会因 FileUriExposedException 而无法安装下载的 APK

  • JSON、APK、Map 文件的 URL 需要支持外链,即可以被直接访问,可考虑放在 Git 仓库、OSS 或自己的服务器上

Alt text

Alt text

Alt text

引入

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。

Apps
About Me
GitHub: Trinea
Facebook: Dev Tools