在对基于Cordova的Android混合App的性能优化过程中,遇到了很多在不同安卓版本手机上的Bug,很多都是安卓不同版本的系统webview的差异导致的,有可能是安卓系统的问题,也有可能是手机厂商修改webkit带来的问题,这些问题从前端技术层面是很难解决的,修改和测试成本都非常高。因此我想通过使用统一webkit内核的大招来解决,目前有2个方案可选,使用Crosswalk内核或腾讯浏览服务X5内核。本文主要研究Cordova整合使用腾讯浏览服务X5内核。
问题背景
熟悉Cordova生态圈的朋友可能听说过Crosswalk,Crosswalk是Intel维护的Webkit开源项目,可以通过插件安装命令cordova plugin add cordova-plugin-crosswalk-webview
安装,它的缺点就是太大了,集成后apk会增加20M,安装后会占用50M空间,因此一般不推荐普通App使用Crosswalk。
然后我就找到了腾讯浏览服务X5,它是直接使用微信/手机QQ/空间的X5浏览器内核的,SDK只有250k,因此可以放心使用。鉴于这几个产品国内广泛的装机量,用户覆盖方面不用担心,如果微信/手机QQ/空间都没有安装,会自动降级到系统浏览器内核,或提示用户安装X5内核。
腾讯X5内核介绍
X5SDK是通过调用微信/手机QQ/空间的X5内核,解决系统webview兼容性差、加载速度慢、功能缺陷等问题,开发接入便捷,大小只有253K,仅需几行代码,即可解决一切令开发者们头疼的问题,为用户提供最优秀的浏览体验。
同时,QQ浏览器团队还将持续更新和优化X5内核,持续优化功能,并保证兼容各种web新特性。
其相对于系统webview,具有下述明显优势:
- 速度快:相比系统webView的网页加载速度有近30%的提升。
- 省流量:云端优化技术使流量节省20%
- 更安全:24小时安全问题解决机制
- 更稳定:经过亿级用户的使用考验,CRASH率0.15%
- 集成强大的视频播放器,支持各种视频格式直接打开
- 适屏排版、字体设置等浏览增强功能的提供
- Html5更完整支持。
- 无系统内核的碎片化问题,更少的兼容性问题
Cordova整合腾讯X5内核
腾讯浏览服务官方只提供了如何把系统Webview替换成X5的接入文档,并没有提供Cordova集成的方法,论坛里有人问这个问题也没有官方回复。现在项目里面用了很多Cordoca插件提供拍照,扫二维码,App支付宝支付等功能,因此就需要把cordova和x5结合起来。
Cordova框架现在已经很完善,Cordova的Web Engine也是基于接口开发的,因此我参考系统engine的实现,写了一个x5engine插件,解决了Cordova调用X5内核的问题。
后面我会把这部分功能做成了一个Cordova插件,方便大家使用,github地址https://github.com/offbye/cordova-plugin-x5engine-webview。
遇到的问题
64位手机上加载包含x5 so文件的插件报错
TBS:initX5Core -- loadSucc: false; exception: java.lang.reflect.InvocationTargetException; cause: java.lang.UnsatisfiedLinkError: dlopen failed: "/data/data/com.tencent.mm/app_tbs/core_share/libmttwebview.so" is 32-bit instead of 64-bit
解决办法是在armeabi增加一个32位的jni so, 随便弄个小一点的so加上就可以,如果已经用了其它的JNI so应该不会有这个错误。X5内核不支持file://本地域url,但支持本地相对路径。