unable to load dynamic library interbase_Android App内部更新Library的方法

3194a994c78108b6639c024dfbf8c5b0.png

超详细!安卓巴士开发者大会嘉宾及主题介绍

d7f55dfe9c83962b86e18e1eb5f08629.png

AutoUpdateProject

最新版本及说明请关注GitHub,欢迎Star。
有什么意见与建议欢迎交流!

github地址:
https://github.com/MZCretin/AutoUpdateProject

公告:移除了之前所有版本的文档说明,从现在起,版本的更新迭代从1.1.2开始进行,之前的老版本使用没有影响,只是不再提供集成说明。

特点概述

一、可从后台主动控制本地app强制更新,主要适用场合是某个版本有bug,会严重影响用户的使用,此时用这种模式,只要用户打开app,提醒强制更新,否则不能进入app;二、根据后台返回受影响的版本号,可控制多个版本同时被强制更新;三、后台返回最新安装包大小,本地判断安装包是否下载,防止多次下载;四、内部处理,忽略此版本更新提示五、library采用无第三方工具类,下载使用HttpURLConnextion,本地存储使用SharedPrefference,以免使用此library带来第三方插件冲突六、library适配Android 7.0七、library默认请求方式为POST请求,对于GET请求无法正常请求,提供配置请求方式八、library添加了对log日志的开关,在调试阶段可打开调试log输出,提交生产环境的时候可以主动的关闭九、library支持判断网络环境,移动数据下智能提示,防止流量外漏。十、考虑到减少与后台人员的配合的高度耦合,增加了自定义model的入口,具体使用请关注使用方式。十一、提供两种模式的版本更新,一种是对话框显示下载进度,一种是通知栏显示后台默默下载形式

使用方式:

第一步、在项目目录下的build.gradle文件下的repositories节点下添加如下代码

... maven { url 

第二步、 在项目app目录下的build.gradle文件下的dependencies节点下添加 { compile 'com.github.MZCretin:AutoUpdateProject:v1.0' }

第三步、 在BaseApplication或者是MainActivity的onCreate()方法中进行初始化(我们推荐在BaseApplication进行初始化,另外不要忘记在AndroidManifest.xml中注册BaseApplication),你有两种初始化的方式,一种是自定义一些参数,另外一种是直接使用默认参数。如下所示:

//第一种形式 自定义参数 

第四步、在AndroidManifest.xml的application节点下添加如下代码:

<applicationandroid:name=".BaseApp"android:allowBackup="true"android:icon="@mipmap/ic_launcher"android:label="@string/app_name"android:supportsRtl="true"android:theme="@style/AppTheme">

第五步、适配Android7.0

在app module 的 res下建立一个xml文件夹,新建一个install_file.xml,在该文件内填写以下内容:

<?xml  version="1.0" encoding="utf-8"?>

在AndroidManifest.xml文件的application标签内填下以下内容

<providerandroid:name="android.support.v4.content.FileProvider"android:authorities="${applicationId}.fileprovider"android:grantUriPermissions="true"android:exported="false"
                >

第六步、必须返回字段的说明

此library的使用需要与后台联动配合,下面是后台需要返回给我们使用的字段说明:

/**
 * Created by cretin on 2017/3/8.
 */

所以需要后台返回给我们这些字段,这些字段都是必须的,相关说明请看注释,下面是一个参考

{
    "versionCode": "18", 
    "isForceUpdate": "1", 
    "preBaselineCode": "0", 
    "versionName": "2.1.1", 
    "downurl": "http://120.24.5.102/Webconfig/frj01_211_jiagu_sign.apk", 
    "hasAffectCodes": "11|12|13|14|15|16|17", 
    "updateLog": "1、修复bug
            2、完善部分功能点
            3、系统升级,强制更新
            ", 
    "size": 10291218
}

情况一:使用默认的model类

sdk默认的model类为UpdateEntity.java,具体如下,你需要保证你们后台返回的json数据可以解析成如下的model类,否则会报无法解析的错误。

/**
 * Created by cretin on 2017/3/8.
 */

情况二:使用自定义的model类

首先,在初始化sdk的时候采用自定义参数的方式,使用 new CretinAutoUpdateUtils.Builder().setTransition(new UpdateModel())方式传入你自定义的model类,请注意,自定义的UpdateModel类必须实现sdk的LibraryUpdateEntity接口,并实现该接口所必须实现的方法,在这些方法中返回给sdk必须的字段,这样sdk才能成功的获取相对应的信息。下面是一个具体的实现:

import com.cretin.www.cretinautoupdatelibrary.model.LibraryUpdateEntity;

下面图片中是必须实现的方法,sdk会根据这些方法返回的数据进行操作,请务必重写!

cbe1df09e0397ea9b298da794125f024.png

第七步、开始使用吧

this).check();

github地址:
https://github.com/MZCretin/AutoUpdateProject

大家都在看

关于Apt注解实践与总结【包含20篇博客】

从零开始跨平台开发 Flutter 1.0 环境搭建

23种设计模式及案例整理分享

一篇文章告诉你MVC、MVP、MVVM

欢迎前往安卓巴士博客区投稿,技术成长于分享

期待巴友留言,共同探讨学习

c3d2ccfcc0b154c2512162dde1446e9b.gif

  • 0
    点赞
  • 0
    评论
  • 0
    收藏
  • 一键三连
    一键三连
  • 扫一扫,分享海报

表情包
插入表情
评论将由博主筛选后显示,对所有人可见 | 还能输入1000个字符
©️2021 CSDN 皮肤主题: 游动-白 设计师:白松林 返回首页
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、C币套餐、付费专栏及课程。

余额充值