距离上一篇初始篇过了一段时间,在初始篇里面主要分享了微信小程序工具 和微信小程序的文件组成
以及小程序架构的基本大纲和描述,看了第一篇的小伙伴应该大概知道了微信小程序运行时候各部分文件职能了,如果不太了解的话可以再去看下 github csdn
核心文件WAService.js WAWebview.js appservice.js的解析 和其他文件在逻辑层和渲染层的:warning:注意事项
websocket通信在微信小程序框架中的应用实现
通过几个案例和部分代码来实现自己的小程序运行环境
微信小程序云开发和小游戏架构初步分析(后续会持续更新)
在第一篇里面有讲到WAService.js文件是在 逻辑层 模版页面里面引入的,但是没有给予过多的介绍, 接下来主要分析下WAService.js的代码组成,这个文件算是微信小程序基础库文件里面很核心的文件了,所以微信对它的保护应该很到位了,微信通过了压缩 编译 打包后生成的一坨这个js文件(如下图)
直接看完全没什么头绪,看着头很重!!
直接执行命令(不要对他抱太大期望,美化后的不可能让你一步到位,还是要慢慢咔哧咔哧)
js-beautify ./WAService.js -r 复制代码
美化后的代码
不过看到结果还是蛮欣慰的
先给大家看下最终大部分解出来的编译文件如下图
下面介绍一个好理解但是有点痛苦的方式,比较清晰的一个操作是在上面我们让它变得美一点了,现在让它变得有条理一些,推荐使用vscode格式化后进行方法折叠
这样一看其实很清晰了我们可以看到这些我们常听说的一些微信对象,WeixinJSBridge、 NativeBuffer、 wxConsole、 WeixinWorker、Reporter、VirtualDom等对象都打包一起了, 然后看到对象里面有很多个function(e,t,n)文件对应的就是每个暴露的方法,下面要做的就是把这些方法的代码手动编译过来,可以给大家一个案例演示下
下图这个是VirtualDom对象文件里面的一个方法
可以先给大家简单分析一点非技术层面的一些疑问,具体的技术层面编译过程,可以熟悉js整个编译历史,和es6转es5的方式推荐大家熟悉下babel源码,可以有很多收获 由于本人也还比较小白(高手可以忽略这点) 大家可以看到
var i=n(22)我改成了const DomIndex=require('./domIndex')这个语句语意可能很多人都可以理解,但我为什么把22这个文件写成DomIndex, 其实这里面的变量和命名和对应的文件都不是自己想当然的,这个可以在文件中进行分析得到的,具体怎么分析的这里不过多介绍了,内容就太多了有兴趣可以留言讨论
使用对 WAService.js文件分析可以看出大致有 : WeixinJSBridge、 NativeBuffer、 wxConsole、 WeixinWorker、 Reporter、 wx、 exparser、 virtualDOM 、 appServiceEngine 等对象组成的
这个大致和WAService.js文件分析方式一样,大家感兴趣的可以自行尝试下,留给大家自己研究,理解的肯定比我写出来的要深刻很多
这个文件分析的结果可以让我们看到一些浮出水面的东西来,但这个过程比较曲折开始 在微信小程序工具的渲染层和逻辑层里面和微信基础库都没有发现这个文件,说明可能是运行时注入进去的(猜测的),
后来在sources里面有发现这个文件
但是文件是空的,页面资源和network里面都没有找到对应的文件,一时比较绝望,后来就一直瞎折腾半天后,终于在工具包里面appservice找到来这个类似文件,让生活注入了一点希望
但是一打开还是这一坨不是人看的代码,但奈何不看不行啊(阿弥陀佛)
通过分析研究发现,还是发现了一些蛛丝马迹,看到了这个文件里面存在webstocket和http通信方式,有通信说明就会和外界有关联,于是大胆尝试了在一些通信相关代码的地方,修改了一点代码和添加了日志
标记三就是稍微在原来微信appservice.js的基础上进行了一点修改,然后保存,期待这微信开发者工具上面会有一些不一样的烟火:fireworks:,但奈何关了又开,开了又关半天屁的变化都没有,于是就产生了自我怀疑,难道不应该这样吗,但是还是感觉方向是对的,于是打算在试试终极解决方法《重启电脑》,果然当我在打开开发者工具的时候看到了不一样的烟火:fireworks:, 在console里面出现了耀眼的光芒,这里应该算一个突破性进展吧!!!
看到api和返回的结果,发现这些其实就是微信提供对外的同步api,可以看到getSystemInfo走的其实是同步的方式,那微信还提供了getSystemInfoSync说明也是同步的,他们的底层实现都是同步的不知道这个api还提供这两个接口有什么意义 没理解, 然后又试了下其他微信提供的同步方法发现都会出现在这里,其他很多异步api的不会走这里都是通过webstocket走的,这里可以得出结论这些同步api请求都是通过/apihelper/assdk传输的,大家可以自己测试下拦截这个请求会发现更多内容。