Android框架RePlugin使用详解

0.先附上一篇原理讲解

https://www.jb51.net/article/127353.htm

这应该算是给作者打的广告吧。如有涉及侵权,请通知我立刻删除。

1.应用场景

Android开发人员不多,又要求使用插件化开发的模式。(简单点讲就是自己需要写宿主APP,还有N多个插件需要开发)

如下图:

360官方给的Demo是宿主一个工程,插件一个工程,并且工程的build.gradle文件中添加宿主和插件对应所需要的依赖,多人开发时,每个人或多个人维护一个宿主工程或者插件工程,都没有什么问题,但是一个人需要同时维护宿主和多个插件时,来回切换工程调试以及打包就异常头疼了。。。

2.一个工程配置宿主和插件的所有依赖

2.1工程的build.gradle文件中添加

buildscript {
 ...
 dependencies {
  classpath 'com.android.tools.build:gradle:2.3.3'
  //插件化框架 宿主工程所需依赖
  classpath 'com.qihoo360.replugin:replugin-host-gradle:2.2.0'
   //插件化框架 插件工程所需依赖
  classpath 'com.qihoo360.replugin:replugin-plugin-gradle:2.2.0'
  ...
 }
 ...
}

2.2宿主app的build.gradle文件中添加

//replugin插件化框架,这一行建议就放在dependencies 的上面,千万不要放在android{...}的上面
apply plugin: 'replugin-host-gradle'

dependencies {
 compile fileTree(include: ['*.jar'], dir: 'libs')
 ...
 releaseCompile project(path: ':library的moudle名字', configuration: 'release')
   debugCompile project(path: ':library的moudle名字', configuration: 'debug')
 compile 'com.qihoo360.replugin:replugin-host-lib:2.2.0'
 ...
}

2.3插件moudle对应的build.gradle文件中添加

//replugin插件化框架,这一行建议就放在dependencies 的上面,千万不要放在android{...}的上面

apply plugin: 'replugin-plugin-gradle'
repluginPluginConfig {
 pluginName = "你自己的插件名字"
 hostApplicationId = "宿主包名"
 hostAppLauncherActivity = "宿主包名.MainActivity"
}

dependencies {
 ...
 releaseCompile project(path: ':library的moudle名字', configuration: 'release')
 debugCompile project(path: ':library的moudle名字', configuration: 'debug')
 compile 'com.qihoo360.replugin:replugin-plugin-lib:2.2.0'
 ...
}

3.宿主及所有插件使用到的library,这里建议自己做成一个moudle,配置方法上面的代码理由了 (library的moudle名字)
如有依赖的冲突,在对应moudle中添加

android{
 ...
 configurations.all {
 resolutionStrategy.eachDependency { DependencyResolveDetails details ->
  def requested = details.requested
  if (requested.group == 'com.android.support') {
   if (!requested.name.startsWith("multidex")) {
    details.useVersion '25.3.1'//这里可根据个人需要改成自己想要的版本
   }
  }
 }
}
...
}

4.关于调试以及成品包。

调试时有几个moudle,就安装几个应用,调用的地方

if (!BuildConfig.DEBUG) {//非Debug,成品包
 if (RePlugin.isPluginInstalled("插件包名")) {
  //已安装
  Intent intentHasInstall = RePlugin.createIntent("插件包名" ,
    "插件包名.MainActivity");
  intentHasInstall.putExtras(bundle);
  RePlugin.startActivity(mContext, intentHasInstall);
  }else{//没有安装,自己写下载的代码}
}else {//debug模式
Intent intent1 = new Intent();
intent1.setComponent(new ComponentName("插件包名", "插件包名.MainActivity"));
intent1.putExtras(bundle);
startActivity(intent1);
}

5.关于FileProvider

5.1这个首先公用library的那个moudle要有一个公用的Utils,并且每个moudle(插件或宿主)都初始化此工具类

public final class Utils {
 private static Context context;
 /**
  * 初始化工具类
  *
  * @param context 上下文
  */
 public static void init(@NonNull final Context context) {
  Utils.context = context.getApplicationContext();
 }

 /**
  * 获取ApplicationContext
  *
  * @return ApplicationContext
  */
 public static Context getContext() {
  if (context != null) return context;
  throw new NullPointerException("请保证你已经初始化过!");
 }
}

5.2每个moudle(插件或宿主)的manifest文件中都添加

<provider
 android:name="android.support.v4.content.FileProvider"
 android:authorities="对应moudle的包名.fileProvider"
 android:grantUriPermissions="true"
 android:exported="false">
 <meta-data
  android:name="android.support.FILE_PROVIDER_PATHS"
  android:resource="@xml/file_paths" />
</provider>

需使用FileProvider时:以获取文件URI为例

File mTmpFile = new File("你自己的文件路径");
Uri uri= FileProvider.getUriForFile(Utils.getContext(), Utils.getContext().getPackageName() + ".fileProvider", mTmpFile);

Utils.getContext().getPackageName(),重点是这个方法;

a.debug时,获取的对应插件的包名,通过每个moudle的manifest配置中对应的fileProvider找到文件;

b.release时,Utils.getContext().getPackageName()获取的只会是宿主的fileProvider,这时自然可以通过宿主manifest配置对应的fileProvider找到文件;

(0)

相关推荐

  • Android插件化-RePlugin项目集成与使用详解

    前言:前一段时间新开源了一种全面插件化的方案-- RePlugin,之前一种都在关注 DroidPlugin 并且很早也在项目中试用了,但最终没有投入到真正的生产环节,一方面是项目中没有特别需要插件化的需求,另一方面也考虑到 DroidPlugin 不是特别稳定,Android系统每更新一次 DroidPlugin 可能就会出现一些 Bug,毕竟 Hook 了 Android 原生的太多东西,系统一旦更新引发 Bug 是在所难免的.当然,这些并不能否认 DroidPlugin 的优秀,它的原理和

  • Android框架RePlugin使用详解

    0.先附上一篇原理讲解 https://www.jb51.net/article/127353.htm 这应该算是给作者打的广告吧.如有涉及侵权,请通知我立刻删除. 1.应用场景 Android开发人员不多,又要求使用插件化开发的模式.(简单点讲就是自己需要写宿主APP,还有N多个插件需要开发) 如下图: 360官方给的Demo是宿主一个工程,插件一个工程,并且工程的build.gradle文件中添加宿主和插件对应所需要的依赖,多人开发时,每个人或多个人维护一个宿主工程或者插件工程,都没有什么问

  • Android中XUtils3框架使用方法详解(一)

    xUtils简介 xUtils 包含了很多实用的android工具. xUtils 支持大文件上传,更全面的http请求协议支持(10种谓词),拥有更加灵活的ORM,更多的事件注解支持且不受混淆影响... xUitls 最低兼容android 2.2 (api level 8) 今天给大家带来XUtils3的基本介绍,本文章的案例都是基于XUtils3的API语法进行的演示.相信大家对这个框架也都了解过, 下面简单介绍下XUtils3的一些基本知识. XUtils3一共有4大功能:注解模块,网络

  • Android 网络请求框架Volley实例详解

    Android 网络请求框架Volley实例详解 首先上效果图 Logcat日志信息on Reponse Volley特别适合数据量不大但是通信频繁的场景,像文件上传下载不适合! 首先第一步 用到的RequetQueue RequestQueue.Java RequestQueue请求队列首先得先说一下,ReuqestQueue是如何对请求进行管理的...RequestQueue是对所有的请求进行保存...然后通过自身的start()方法开启一个CacheDispatcher线程用于缓存调度,开

  • Android AOP框架AspectJ使用详解

    前言 之前了解过android的AOP框架,用法主要用来打日志:现在有一个需求需要函数在新线程中执行,并且函数主体执行完之后,在UI线程返回结果.想到手写的话,每次都要new Thread的操作,比较麻烦:因此就尝试用注解的方法解决这个问题. AspectJ的使用核心就是它的编译器,它就做了一件事,将AspectJ的代码在编译期插入目标程序当中,运行时跟在其它地方没什么两样,因此要使用它最关键的就是使用它的编译器去编译代码ajc.ajc会构建目标程序与AspectJ代码的联系,在编译期将Aspe

  • Android分包MultiDex策略详解

    1.分包背景 这里首先介绍下MultiDex的产生背景. 当Android系统安装一个应用的时候,有一步是对Dex进行优化,这个过程有一个专门的工具来处理,叫DexOpt.DexOpt的执行过程是在第一次加载Dex文件的时候执行的.这个过程会生成一个ODEX文件,即Optimised Dex.执行ODex的效率会比直接执行Dex文件的效率要高很多. 但是在早期的Android系统中,DexOpt有一个问题,DexOpt会把每一个类的方法id检索起来,存在一个链表结构里面.但是这个链表的长度是用一

  • Android AOP注解Annotation详解(一)

    Android 注解Annotation 相关文章: Android AOP注解Annotation详解(一) Android AOP之注解处理解释器详解(二) Android AOP 注解详解及简单使用实例(三) Android AOP 等在Android上应用越来越广泛,例如框架ButterKnife,Dagger2,EventBus3等等,这里我自己总结了一个学习路程. - Java的注解Annotation - 注解处理解析器APT(Annotation Processing Tool)

  • Android View.onMeasure方法详解及实例

    Android View.onMeasure方法详解及实例 View在屏幕上显示出来要先经过measure(计算)和layout(布局). 1.什么时候调用onMeasure方法? 当控件的父元素正要放置该控件时调用.父元素会问子控件一个问题,"你想要用多大地方啊?",然后传入两个参数--widthMeasureSpec和heightMeasureSpec. 这两个参数指明控件可获得的空间以及关于这个空间描述的元数据. 更好的方法是你传递View的高度和宽度到setMeasuredDi

  • RN在Android打包发布App(详解)

    1-:生成一个签名密钥 你可以用keytool命令生成一个私有密钥.在Windows上keytool命令放在JDK的bin目录中(比如C:\Program Files\Java\jdkx.x.x_x\bin),你可能需要在命令行中先进入那个目录才能执行此命令.在mac上,直接进入项目根目录输入一下命令: $ keytool -genkey -v -keystore my-release-key.keystore -alias my-key-alias -keyalg RSA -keysize 2

  • 基于Android RxCache使用方法详解

    前言 我为什么使用这个库? 事实上Android开发中缓存功能的实现选择有很多种,File缓存,SP缓存,或者数据库缓存,当然还有一些简单的库/工具类,比如github上的这个: [ASimpleCache]:a simple cache for android and java 但是都不是很好用(虽然可能学习成本比较低,因为它使用起来相对简单),我可能需要很多的静态常量来作为key存储缓存数据value,并设置缓存的有效期,这可能需要很多Java代码去实现,并且过程繁琐. 如果您使用的网络请求

  • Android LitePal的使用详解

    前言 数据库操作一直都是比较繁琐而且单一的东西,平时开发中数据库也很常见.有学过mysql的读者可能会觉得sql语句确实让人很难受.同样android中,虽然有内置数据库SQLite,但是操作起来还是非常的不方便.跟网络请求类似,当我们用原生的HttpURLConnection请求数据再用json解析,过程很繁琐,所以我们一般是封装成一个工具类,但是retrofit出现了,他帮我们解决了网络请求和解析数据的封装,同时还支持RxJava的异步,十分强大.不了解retrofit的读者也建议你们去学习

随机推荐