其实本来不打算写这篇文章的,因为其实官方文档已经非常详细了。没错,以下内容基本与官方文档雷同。
1.首先,需要去阿里云官网注册帐号,已有阿里云帐号的无需再次注册(此步骤略)。
2.登录移动热修复控制台(https://hotfix.console.aliyun.com/),创建相关产品,如下图所示:
3.点击创建后,可以直接看到当前的产品列表,如下图所示:
4.点击产品名称或者产品对应的管理链接进入产品的应用列表创建相应的应用,如下图所示:
5.点击创建应用按钮,填写App名称,应用类型,packageName及相关描述信息
(注:此处的应用类型选择Android,packageName为实际应用对应的包名)
6.创建完成后点击左侧服务列表选择移动热修复,进入移动热修复控制台,如下图所示:
7.在App列表点击“管理”后,跳转到单个App管理页面,可以查看,如下图所示:
8.打开androidstudio中对应的项目,在根节点的build.gradle文件中添加maven仓库地址,如下:
maven {
url "http://maven.aliyun.com/nexus/content/repositories/releases"
}
在项目的build.gradle文件中添加gradle坐标版本依赖:
compile 'com.aliyun.ams:alicloud-android-hotfix:3.1.7'
9.相关权限的添加
<uses-permission android:name="android.permission.INTERNET" />
<uses-permission android:name="android.permission.ACCESS_NETWORK_STATE" />
<uses-permission android:name="android.permission.ACCESS_WIFI_STATE" />
<uses-permission android:name="android.permission.READ_EXTERNAL_STORAGE" />
10.在AndroidManifest.xml中间的application节点下添加如下配置:
<meta-data android:name="com.taobao.android.hotfix.IDSECRET" android:value="AppId" />
<meta-data android:name="com.taobao.android.hotfix.APPSECRET" android:value="AppSerect" />
<meta-data android:name="com.taobao.android.hotfix.RSASECRET" android:value="RSA密钥"/>
(注:此处填写的相关参数为步骤7所获取)
11.代码混淆(此步骤略,可根据项目需求去官网获取最新的代码混淆文件)
12.Application初始化(简单范例)
@Overrideprotected void attachBaseContext(Context base) {
super.attachBaseContext(base);
String appVersion;
try { appVersion = this.getPackageManager().getPackageInfo(this.getPackageName(), 0).versionName;
} catch (Exception e) {
appVersion = "1.0.1"; }
// initialize最好放在attachBaseContext最前面,初始化直接在Application类里面,切勿封装到其他类
SophixManager.getInstance().setContext(this)
.setAppVersion(appVersion)
.setAesKey(null)
.setEnableDebug(true)
.setPatchLoadStatusStub(new PatchLoadStatusListener() {
@Override
public void onLoad(final int mode, final int code, final String info, final int handlePatchVersion){
// 补丁加载回调通知
if (code == PatchStatus.CODE_LOAD_SUCCESS) {
// 表明补丁加载成功
Log.d(TAG, "补丁加载成功");
} else if (code == PatchStatus.CODE_LOAD_RELAUNCH)
{ Log.d(TAG, "发现新补丁,建议重启应用");
// 表明新补丁生效需要重启. 开发者可提示用户或者强制重启;
// 建议: 用户可以监听进入后台事件, 然后调用killProcessSafely自杀,以此加快应用补丁,详见1.3.2.3
}
}
}).initialize();}
@Override
public void onCreate(){
super.onCreate();
SophixManager.getInstance().queryAndLoadNewPatch();
}
(注:到此步骤已完成最基本的集成,注意此处传入的appVersion对应于平台上你添加的相应版本,上传补丁是针对对应版本上传的)
13.生成插件
下载官方插件工具一键生成(注:本地环境jdk版本必须大于1.7,否则生成不会成功;另需注意的是每次生成插件都是根据两个包对比生成的,假定现在有一个基准包,第一次新包里面添加一个功能生成一个插件,第二次新包没有该功能而是单纯的修复bug,那么先发布第一个插件再发布第二个生成的插件,添加的功能会消失《说到这里,可以想象目前插件化比较实用的几个场景,场景1:修复在线新包的bug,较为常见;场景2:一些bug在新版本上已经修复,但由于新版本上添加了一些功能,老用户不想要,即切换到当时开发的节点,获取当时的版本,生成一个老包,然后在对应节点上修复ok后,生成新包后再进行插件的生成场景3:添加一些布局文件及方法,即一些UI的简单修改)
14.在相应版本上上传插件然后发布版本(次步骤较为简单略)
以上就为集成的简要步骤,自己按这个步骤傻瓜式的走了一遍并且测试成功。