Cordova整合使用腾讯浏览服务X5内核

在对基于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,具有下述明显优势:

  1. 速度快:相比系统webView的网页加载速度有近30%的提升。
  2. 省流量:云端优化技术使流量节省20%
  3. 更安全:24小时安全问题解决机制
  4. 更稳定:经过亿级用户的使用考验,CRASH率0.15%
  5. 集成强大的视频播放器,支持各种视频格式直接打开
  6. 适屏排版、字体设置等浏览增强功能的提供
  7. Html5更完整支持。
  8. 无系统内核的碎片化问题,更少的兼容性问题

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

遇到的问题

  1. 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应该不会有这个错误。

  2. X5内核不支持file://本地域url,但支持本地相对路径。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 关于这份调研报告,不是从技术角度深入探索,重点是从产品本身分析,通俗易懂才是重点。主要是为了锻炼平时做技术调研和竞...
    石先阅读 23,670评论 13 48
  • 问题: 从研发cordova混编App开发开始,不同安卓版本手机上的兼容性问题就困扰着研发的童鞋们。Cordova...
    谢大见阅读 5,034评论 1 7
  • 浏览器发展史 现在浏览器已经成为网上生活的重要家园和工具。而从1991年,Web之父Tim Berners-Lee...
    波段顶底阅读 17,261评论 6 86
  • 导读 1、什么是X5内核? 2、需求场景 3、开始搬砖 4、优化 5、补充:去除QQ浏览器推广 (ps:由...
    b77535296c81阅读 27,765评论 14 26
  • 最简单的单元测试1.新建项目: 2.最简单的测试,注意截图路径的问题进入到这个类,setUp是每个测试方法调用前执...
    清风沐沐阅读 1,391评论 1 0