RePlugin插件化的问题和解决办法

这篇文章基于 Replugin2.2版本的,后续可能会随着框架改动和bug修复有些问题可能就不存在了。如果你跟我一样也是对插件化开发跃跃欲试,又在里面栽跟头了,我想本片文章可能会对大家提供点小小的帮助。最终问题的解决还是离不开对框架原理的熟悉。否则遇到了问题也不知道从何下手。孤陋寡闻的我可能踩了一些很低级的错误,还望各位大大们在发现本文讲得不对的地方指正。

目录

  • 插件使用宿主的对象
  • v7包
  • 插件横屏
  • 热更新插件
  • 坑位之显示Intent无效
  • 插件和宿主同工程的问题
  • 幽灵魔术

插件使用宿主的对象

1.我想在插件中使用宿主的new出来的对象,但是如果在插件中和宿主中同时依赖一份资源是无法使用的,会报类转化异常。比如宿主和插件都要用okhttp3,但是我不想插件中也要初始化一个。

答:
只在宿主中通过dependencies的方式依赖一下,然后将工程切换成Project模式。如下图

找到这个依赖文件,在jar文件上右键打开目录。

将这个jar文件拷贝到你的插件目录下。然后通过provided的方式进行编译依赖。

 provided files('libs/xxx.jar')

注意,provided仅仅是编译依赖,不会打包进apk包里。这样当Replugin框架在dex加载的时候拿到的就是宿主的class。就不会造成类转化异常了。

小技巧提示:
如果你的插件需要公共host里面的一些类和基础服务。(注意不含资源,资源指图片和xml)
可以在host里剥离出一个模块,让host去依赖它,然后将该模块打包成jar的方式,提供给插件使用。犹如sdk的开发模式,但是一定要注意务必使用provided关键字。莫打包进去了。

模块打包成jar的方式如下:

在依赖模块中的gradle里添加配置:

android {
  lintOptions {
        abortOnError false
    }

 }
//注意makeJar放在外层 
task makeJar(type: Jar, dependsOn: ['build']) {
    destinationDir = file('build/outputs/jar/')
    baseName = "AppSDK"
    version = "1.0.0"
    from('build/intermediates/classes/debug')
    exclude('**/BuildConfig.class')
    exclude('**/BuildConfig\$*.class')
    exclude('**/R.class')
    exclude('**/R\$*.class')
    include('**/*.class')
}

打开gradle命令列表(在as的右侧,看到没?)
找到该模块的的other选项

找到 makeJar

ok,这样就编译好了,接下来复制到插件的libs里 provided files一下即可。

这里比较麻烦的事是,每当你修改过这个依赖模块的代码都需要重写打包一份jar。项目上线后如果宿主没有升级,那么最好不要改动依赖模块中的代码。


v7包

1.插件布局加载后莫名其妙的多了一些外边距,无法全屏 独立运行是正常的

答:
插件不能共享资源宿主的v7包,注意如果你违反这条去尝试开发插件。会导致你的插件apk布局莫名其妙的多出一些边距。

注意:
即便插件中你没有依赖v7包,也是可以使用AppCompatActivity的。但是包里不会包含v7包的资源。
是因为SdkVersion版本过高所以可以直接使用。

解决办法:
在插件中单独依赖一份v7包,而不是共享宿主的。


2.插件中加载的布局是上一个宿主的布局

答:
你使用了基础的Activity,没有使用v7包里的AppCompatActivity并且关闭了 useAppCompat = false

解决办法:
如果你的抛资源找不到错误,先尝试使用RePlugin.getPluginContext() 取获取资源。
加载布局文件配合 LayoutInflater.from()。塞入View。或者直接替换成AppCompatActivity就没有这个问题了。(推荐用AppCompatActivity问题会少很多)


插件横屏

插件目前manifest配置了横屏是无效的。这也许是坑位导致的,可以动态在onCreate的时候改变一下

  protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        if (getRequestedOrientation() != ActivityInfo.SCREEN_ORIENTATION_LANDSCAPE) {
            setRequestedOrientation(ActivityInfo.SCREEN_ORIENTATION_LANDSCAPE);
        }
          ·····
}


热更新插件

wiki文档里已经讲过了,对于没有启动(加载过)的插件是可以安装后就运行的。但是若插件被启动过或正在运行时则不行。针对特殊的应用场景不得不重启app,而且还是主动重启。
那么发现如果开启了 persistentEnable = true 常驻应用内存。(就是一个服务)会导致即便重启了app,插件安装后还是没有被更新。这里迫使我关掉了persistentEnable选项,随后重启后就成功更新了。注意我这里说的重启是非root下,应用自己杀死自己,而非用户主动kill掉。


坑位之显示Intent无效

比如广播,这种如果你试图在配置文件中静态注册的方式去声明一个广播。并没有给出。简单来说就是intent-filter没有设置。

正确的做法是使用隐式Intent。

代码如下:

 <receiver android:name=".xxx$AlarmReceiver" >
            <intent-filter>
                <action android:name="xxx" />
            </intent-filter>
            </receiver>
  Intent intent = new Intent();
  intent.setAction("xxx");

这样就可以了。因为坑位上目前没有使用显示调用的方式。

插件和宿主同工程的问题

如果你还没有建项目,兄弟,听我一句劝。别建在同一个工程下。如果你已经建立了,赶快剥离。有毒 有毒。准备折腾死就放在一起吧。后面的毛病越来越多。虽然我之前也是放在了一个工程下强行编译过去了。但是实际后面的体验告诉我出了很多问题。
1.编译会满,资源占用更多。
2.开发混乱,不利于管理。
3.莫名其妙的打包错误。比如下方这样的:(注意:这个错误是突然莫名其妙出现的,我发誓在出错误之前没有碰过依赖和gradle里的配置。)

* What went wrong:
Execution failed for task ':app:rpGenerateReleaseBuiltinJson'.
> java.util.zip.ZipException: zip file is empty

详细日志省略,见Issues:
https://github.com/Qihoo360/RePlugin/issues/380

幽灵魔术

什么叫幽灵魔术问题?就和变魔术一样,我好像没有改什么逻辑性的代码,突然bug又好了。
多半是你动了rePlugin中的gradle里的配置项,可能留下了上一次的缓存在里面,你要做的就是每当改动了gradle里的配置最好搭配Clean Project一下。如下图:

然后有其他问题可以去参考https://github.com/Qihoo360/RePlugin/issues。如果找不到的情况下可以加官方的群。里面还是比较活跃的。

这里再次说明一个问题,跑demo玩测一测和距离正式项目使用还是有很大的区别的。很多问题在demo里看不出来的,只有真正用的时候才会踩到。尽管说replugin的文章说只hook了一个点来确保稳定性。但是由于开发人员对框架本身的不够熟悉,和存在的一些bug。导致接入成本不能说极低了。如果要考虑团队使用,最好由提前做有一个人来做预研接入再推广给大家使用。熟悉这种模式后,可能会是如虎添翼。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 157,298评论 4 360
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 66,701评论 1 290
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 107,078评论 0 237
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 43,687评论 0 202
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 52,018评论 3 286
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 40,410评论 1 211
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 31,729评论 2 310
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 30,412评论 0 194
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 34,124评论 1 239
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 30,379评论 2 242
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 31,903评论 1 257
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 28,268评论 2 251
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 32,894评论 3 233
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 26,014评论 0 8
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 26,770评论 0 192
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 35,435评论 2 269
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 35,312评论 2 260

推荐阅读更多精彩内容