360插件化RePlugin踩坑

点击图片购书

1.什么是RePlugin?

在Android开发领域,有关插件化的讨论一直热度不减。目前市面上的插件化方案虽然很多,但多数只能实现某些功能的插件化,距离开发者的预期尚有相当差距。对此,在近期GMTC全球移动技术大会上,360手机卫士主程序架构负责人张炅轩宣布,360的插件化框架RePlugin已经可以实现“全面插件化”,同时具有出色的稳定性和灵活性,可适用于各种类型的应用上。
“RePlugin预计7月份开源,这将是我们献给安卓世界最好的礼物。”360如是说。

2.RePlugin有什么用?

RePlugin是一套完整的、稳定的、适合全面使用的,占坑类插件化方案,由360手机卫士的RePlugin Team研发,也是业内首个提出”全面插件化“(全面特性、全面兼容、全面使用)的方案。

3.RePlugin官方介绍

其主要优势有:

  • 极其灵活:主程序无需升级(无需在Manifest中预埋组件),即可支持新增的四大组件,甚至全新的插件
  • 非常稳定:Hook点仅有一处(ClassLoader),无任何Binder Hook!如此可做到其崩溃率仅为“万分之一”,并完美兼容市面上近乎所有的Android ROM
  • 特性丰富:支持近乎所有在“单品”开发时的特性。包括静态Receiver、Task-Affinity坑位、自定义Theme、进程坑位、AppCompat、DataBinding等
  • 易于集成:无论插件还是主程序,只需“数行”就能完成接入
  • 管理成熟:拥有成熟稳定的“插件管理方案”,支持插件安装、升级、卸载、版本管理,甚至包括进程通讯、协议版本、安全校验等
  • 数亿支撑:有360手机卫士庞大的数亿用户做支撑,三年多的残酷验证,确保App用到的方案是最稳定、最适合使用的

截止2017年6月底,RePlugin的:

目前360公司几乎所有的亿级用户量的APP,以及多款主流第三方APP,都采用了RePlugin方案。

有关RePlugin的详细介绍,请点击这里阅读《RePlugin 官方 WiKi》

还支持以下特性

愿景

让插件化能飞入寻常应用家,做到稳定、灵活、自由,大小项目兼用。

RePlugin 架构图

RePlugin Framework

4.SO?怎么用?

ok,看完了官方介绍给我们画的大饼,现在看看怎么实现它,是的,坑来了。。
主程序的配置,这里就不多说了。。将RePlugin接入到您的主程序,官方文档描述的很清楚,也没有什么奇奇怪怪的错误。
主要来说说如何开发新的 RePlugin 插件,从RePlugin的Wiki我们可以看到,好简单呀,就三步嘛,来吧。
然后我们碰到了.........

问题一:Gradle配置出错

EXCUSE ME?那里有问题?再看看文档,没啥特别的描述呀。
然后,我在Issues里找到了官方项目组说的这一句:“这个要自动读取前面build.gradle的配置内容,如果放在前面,会读为空。我们内部讨论过这个问题,如果要想自由放置就得传参配置。当时考虑到尽量减少传参配置就约定俗成让放在文件末尾。你可以看demo1。”
好吧,既然如此能不能提一句只能放在文件末尾啊!
你是360,你老大,我改!

gradle配置出错.png

??按你说的还不行??
然后,我在Issues里看到了吃瓜群众说的这一句:“你试试把apply plugin: 'replugin-plugin-gradle'放在<apply plugin: 'com.android.application'之前就好了,我的就是这样好使的,你试试?”
抱着试一试的心态,然后我发现...成功了??说好的读取配置内容呢?说好的会读为空呢?

OK,按照官方文档,各项都配置完成,我们继续进行。。
插件界面很简单:

插件单独运行一下,ok,没问题。
好的,接下来走一下内置插件的流程,将插件项目build一个apk出来,后缀改成jar,导入主程序assets的plugins内,
主程序界面也很简单,就一个HelloRePlugin的TextView,给TextView设置一个点击事件

然后我们碰到了.........

问题二:主题出错

点击HelloRePlugin,程序崩溃。

主题出错

主题错了?继承的是Activity啊,有主题啊,单独运行没有错啊。。
自此,我开始多番尝试之路,改了n个主题发现没有用,气的我,直接把apply plugin: 'replugin-plugin-gradle'
我把这句去掉了,运行。。程序调起成功了。。。我的天哪
诡异的一幕出现了,吊起的插件Acitivity显示界面:

主题错误

???这个界面哪来的?,这不是我的插件界面啊。。
奇怪的是,插件的activity的onCreate也走了。那我的界面去哪了?
是不是因为我删去了apply plugin: 'replugin-plugin-gradle',所以出现问题了?,还是加上吧,再看看主题出错有没有其他解决方法。------加上,buildApk,导入主程序,运行主程序,点击HelloRePlugin,调起,成功了?!,唉?你不是主题有问题的吗?你不是主题有问题的吗?你不是主题有问题的吗?好吧,,虽然调起成功,可是还没完,打开的activity界面依然如上。

网络图片

然后我们发现了.........

问题三: Didn't find class "com.qihoo360.plugin.app2.Entry"

 1 Didn't find class "com.qihoo360.plugin.app2.Entry" on path: DexPathList[[zip file "/data/user/0/com.replugindemo/app_plugins_v3/app2-10-10-101.jar"],nativeLibraryDirectories=[/data/user/0/com.replugindemo/app_plugins_v3_libs/app2-10-10-101, /vendor/lib, /system/lib]] 2 java.lang.ClassNotFoundException: Didn't find class "com.qihoo360.plugin.app2.Entry" on path: DexPathList[[zip file "/data/user/0/com.replugindemo/app_plugins_v3/app2-10-10-101.jar"],nativeLibraryDirectories=[/data/user/0/com.replugindemo/app_plugins_v3_libs/app2-10-10-101, /vendor/lib, /system/lib]] 3                 at dalvik.system.BaseDexClassLoader.findClass(BaseDexClassLoader.java:56) 4                 at java.lang.ClassLoader.loadClass(ClassLoader.java:511) 5                 at com.qihoo360.replugin.PluginDexClassLoader.loadClass(PluginDexClassLoader.java:76) 6                 at java.lang.ClassLoader.loadClass(ClassLoader.java:469) 7                 at com.qihoo360.loader2.Loader.loadEntryMethod2(Loader.java:419) 8                 at com.qihoo360.loader2.Plugin.loadEntryLocked(Plugin.java:857) 9                 at com.qihoo360.loader2.Plugin.doLoad(Plugin.java:822)10                 at com.qihoo360.loader2.Plugin.loadLocked(Plugin.java:621)11                 at com.qihoo360.loader2.Plugin.load(Plugin.java:432)12                 at com.qihoo360.loader2.PmBase.loadPlugin(PmBase.java:1033)13                 at com.qihoo360.loader2.PmBase.loadAppPlugin(PmBase.java:1018)14                 at com.qihoo360.loader2.PmLocalImpl.getActivityInfo(PmLocalImpl.java:443)15                 at com.qihoo360.loader2.PmLocalImpl.loadPluginActivity(PmLocalImpl.java:319)16                 at com.qihoo360.loader2.PmInternalImpl.startActivity(PmInternalImpl.java:230)17                 at com.qihoo360.loader2.PmLocalImpl.startActivity(PmLocalImpl.java:307)18                 at com.qihoo360.i.Factory.startActivityWithNoInjectCN(Factory.java:324)19                 at com.qihoo360.replugin.RePlugin.startActivity(RePlugin.java:236)20                 at com.zzcn77.replugindemo.MainActivity$1.onClick(MainActivity.java:24)21                 at android.view.View.performClick(View.java:5198)22                 at android.view.View$PerformClick.run(View.java:21147)23                 at android.os.Handler.handleCallback(Handler.java:739)24                 at android.os.Handler.dispatchMessage(Handler.java:95)25                 at android.os.Looper.loop(Looper.java:148)26                 at android.app.ActivityThread.main(ActivityThread.java:5417)27                 at java.lang.reflect.Method.invoke(Native Method)28                 at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:726)29                 at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:616)30                 Suppressed: java.lang.ClassNotFoundException: com.qihoo360.plugin.app2.Entry31                 at java.lang.Class.classForName(Native Method)32                 at java.lang.BootClassLoader.findClass(ClassLoader.java:781)33                 at java.lang.BootClassLoader.loadClass(ClassLoader.java:841)34                 at java.lang.ClassLoader.loadClass(ClassLoader.java:504)35                     ... 25 more36Caused by: java.lang.NoClassDefFoundError: Class not found using the boot class loader; no stack trace available

为什么?

再看看官方文档,遗漏什么了?没有啊。
再看看官方文档,还有没看到的?没有啊。
为什么?
再回想一下整个流程,gradle出错,主题样式错误,Didn't find class "com.qihoo360.plugin.app2.Entry
对,主题样式,这一环并没有真正的解决。
找不到主题?application里面配置的有主题呀。
把application的统一主题去掉,分别给每个activity配置主题。
再来一次,buildApk,导入主程序,运行主程序,调起,成功了!!!完美运行!!!
掌声,掌声,掌声

总结

首次的整个集成过程,也算是踩坑无数,乐趣多多啊。希望Replugin项目组在后续的版本中能够提供更多的功能,以及更高的稳定性,当然也希望官方的Wiki再友好一点,能对一些集成规范的描述更详细点呗。不过好用是真的。
作为行业大哥360开源出来的全面化插件机制,以及在360众多项目中的实践,Replugin的功能性,肯定是毋庸置疑的,应用场景也必将十分广泛。相信在未来很多项目中,会见到它的身影。

本文摘自异步社区,发表人:xiangzhihong ,作品《360插件化RePlugin踩坑》未经授权,禁止转载。


推荐阅读


2018年5月新书书单(文末福利)

2018年4月新书书单

异步图书最全Python书单

一份程序员必备的算法书单

第一本Python神经网络编程图书

长按二维码,可以关注我们哟

每天与你分享IT好文。

在“异步图书”后台回复“关注”,即可免费获得2000门在线视频课程

点击阅读原文,查看更多内容

原文地址:http://blog.51cto.com/13127751/2126490

时间: 2024-08-28 17:42:37

360插件化RePlugin踩坑的相关文章

360手机卫士插件化RePlugin今日开源

写在前面 "RePlugin将在6月底开源,这将是我们献给安卓世界最好的礼物."当我们宣布这一消息时,心中的激动,无以言表.是的,三年的"厚积",如今的"薄发",看似平凡的话,实际上却饱含了我们太多的激动.辛酸与泪. 那么今天,我们就来详细的和您聊一聊,这个从2014年中旬,正式在手机卫士上启用,并即将开源的360 RePlugin,究竟能为我们,更为您能带来什么. GitHub地址:https://github.com/Qihoo360/ReP

罗列几个Android插件化开发框架

携程插件化框架 ACDD插件化框架 360插件化框架 Android-Plugin-Framework DL APK动态加载框架 部分框架对比 DynamicLoadApk 迁移成本很重:需要使用『that』而不是『this』,所有activity都需要继承自proxy avtivity(proxy avtivity负责管理所有activity的生命周期). 无法启动apk内部的activity. 不支持Service和BroadcastReceiver. AndroidDynamicLoade

【踩坑】360安全浏览器“极速模式”和“兼容模式”,套路还是bug?

分享踩坑点: 项目中需要兼容360安全浏览器,大家当然都希望用极速模式打开网站,但是发现总是被兼容模式打开 网址类似 aa.xx.dd.com 网上找了很多地方,有以下两种方法 1.<meta http-equiv=X-UA-Compatible content="IE=edge,chrome=1"> 2.<meta name="renderer" content="webkit"> -------------------

怎样将「插件化」接入到项目之中?

本期移动开发精英社群讨论的主题是「插件化」,上网查了一下,发现一篇 CSDN 博主写的文章<Android 使用动态载入框架DL进行插件化开发>.此处引用原作者的话: 随着应用的不断迭代,应用的体积不断增大,项目越来越臃肿,冗余添加.项目新功能的加入,无法确定与用户匹配性,发生严重异常往往牵一发而动全身,仅仅能紧急公布补丁版本号,强制用户进行更新.结果频繁的更新.反而easy减少用户使用黏性,或者是公司业务的不断发展,同系的应用越来越多,传统方式须要通过用户量最大的主项目进行引导下载并安装.

DroidPlugin插件化开发

360手机助手使用的 DroidPlugin,它是360手机助手团队在Android系统上实现了一种插件机制.它可以在无需安装.修改的情况下运行APK文件,此机制对改进大型APP的架构,实现多团队协作开发具有一定的好处. 它是一种新的插件机制,一种免安装的运行机制 github地址: https://github.com/DroidPluginTeam/DroidPlugin 参考博客:http://blog.csdn.net/hejjunlin/article/details/52124397

如何将「插件化」接入到项目之中?

本期移动开发精英社群讨论的主题是「插件化」,上网查了一下,发现一篇 CSDN 博主写的文章<Android 使用动态加载框架DL进行插件化开发>.此处引用原作者的话: 随着应用的不断迭代,应用的体积不断增大,项目越来越臃肿,冗余增加.项目新功能的添加,无法确定与用户匹配性,发生严重异常往往牵一发而动全身,只能紧急发布补丁版本,强制用户进行更新.结果频繁的更新,反而容易降低用户使用黏性,或者是公司业务的不断发展,同系的应用越来越多,传统方式需要通过用户量最大的主项目进行引导下载并安装.怎么办?这

AI相关 TensorFlow -卷积神经网络 踩坑日记之一

上次写完粗浅的BP算法 介绍 本来应该继续把 卷积神经网络算法写一下的 但是最近一直在踩 TensorFlow的坑.所以就先跳过算法介绍直接来应用场景,原谅我吧. TensorFlow 介绍 TF是google开源出来的人工智能库,由python语言写的 官网地址:http://www.tensorflow.org/   请用科学上网访问 中文地址:http://www.tensorfly.cn/ 当然还有其他AI库,不过大多数都是由python 写的 .net 的AI库叫 Accord.net

网站移动版本开发踩坑实录一

最近公司项目需要开始做wap版本开发,虽然在上一家公司也有做过类似的工作,由于当时公司产品没有严格要求适配各个移动设备,也并没有很多动作效果和图片自适应这类的效果,相对来说体系没有那么成熟,更多是在wap版本上可以用就ok了(其实更多的工作集中在功能和cssser身上,交互效果没有那么强,唯一做的好玩一点的工作是菜单滑动.图片缩放[未被上线过]),因此基本上没有在移动端踩各种坑:说了这么多上一家公司的wap版本,下面开始讲讲现在做的项目让我在wap版本上踩的各种坑开始说起.   第一坑:技术选型

jQuery版本升级踩坑大全

背景 -------------------------------------------------------------------------------- jQuery想必各个web工程师都再熟悉不过了,不过现如今很多网站还采用了很古老的jQuery版本.其实如果早期版本使用不当,可能会有DOMXSS漏洞,非常建议升级到jQuery 1.9.x或以上版本.前段时间我就主导了这件事情,把公司里我们组负责的项目jQuery版本从1.4.2升级到了jQuery 1.11.3.jQuery官