实现微信小程序编译和运行环境系列(初始篇)

前言

最近一段时间在研究实现微信小程序和小游戏编译打包和运行环境平台开发

目前基本可以支持微信基础库2.8.2功能迭代了

所以想通过记录分享一下自己的认知过程中遇到的一些问题和解决方案来更好的理解小程序设计上的优点和一些不足的地方

在此之前网上有存在开源的一些基于微信基础库版本1.0的一些参考
核心作者是由开源大牛启明兄的wept项目基础上构建的(目前有幸和启明兄成为同事对这个小程序整体的架构理解帮助了我很多)

由于wept的运行环境是基于微信基础库1.0的版本上实现之后也不维护了,时间上是2016的在后续的更新的版本中新加的一些特性如自定义组件 npm包很多api等开发实现都不支持,
最主要是的微信在后续架构中更换底层的通信方式采用了webstock的方式等一些其他变化


正文

后面我会通过几篇文章来整体描述一下从工具到破解到源码解析和原理到实现的处理流程

最开始的时候也在网上找了很多的资料,看了有一些人写的解析微信小程序架构的文章,从中学习了解了很多

但如果想模拟实现出来这么个东西 还是有蛮迷糊的,所以我想通过我们所实现的过程来一点点从现象 看本质来解析下微信小程序编译和运行原理

凡事对自己多点信心 多坚持下 多学习下,想想我们遇到的问题,当时感觉我 搞不定了 弄不了
最后随着时间的推移和认知的迭代问题总会慢慢消灭掉


本文将先通过全面解析微信开发者工具来知道那些基本的文件和内容组成一一讲述(从现象 看本质)

在此之前我们通过官方文档可以了解一些内容

  • 整个小程序框架系统分为两部分:逻辑层(App Service)和 视图层(View)

  • 小程序提供了自己的视图层描述语言 WXML 和 WXSS

  • 基于 JavaScript 的逻辑层框架,并在视图层与逻辑层间提供了数据传输和事件系统他们两个线程里运行

  • 视图层使用WebView渲染,逻辑层使用JSCore运行, 视图层和逻辑层通过系统层的JSBridage进行通信,逻辑层把数据变化通知到视图层,触发视图层页面更新,
    视图层把触发的事件通知到逻辑层进行业务处理

从上述说明中我们可以得知一些重要信息逻辑层(App Service)和 视图层(View) 以及两者之间的通信协调

下面通过微信开发工具来展示说明,小程序逻辑层的 javascript 代码是运行在 NW.js 中,视图层是由 Chromium 60 Webview 来渲染的
他们之间是通过webstock协议来通信的

以下我们主要是以mac环境为主

我们先打开 微信开发工具官方demo 如图

1

从上图和我们的一些理解我们知道微信小程序的文件格式主要组成

  • .js 主要页面逻辑
  • .wxml 页面结构,框架设计的一套标签语言,结合基础组件、事件系统,可以构建出页面的结构。
  • .wxss 是一套样式语言,用于描述 WXML 的组件样式。
  • .json 页面配置按照『约定优于配置』的原则。

接下来我们先找到本机微信开发者工具应用包里面如图

2

我们后面分析的主要代码都在package.nw里面和core.wxvpkg

这些文件在后面实现过程中都会使用说明用途的

  • js文件里面的内容主要是在页面和逻辑层的渲染用,后面将会看到
  • core.wxvpkg是这个里面的核心文件破解这个包可以知道很多逻辑可以先给大家看下解压后包的结构

3 4

core.wxvpkg解压代码上传在unwxvpkg大家有兴趣可以自己先试试


接下来我们回到开发者工具中打开

微信开发者工具–》调试–》调试微信开发者工具

7

打开调试后我们可以看到的界面如下:

6

从上面的现象我们可以看出他的两层渲染层和逻辑层结构是包含在两个webview里面

第一个对应的webview是渲染层的每个页面都对应一个地址

但逻辑层appservice只有一个不变的

下来我们可以看看这个webview里面是个什么东

如果我们直接把view层的webview标签改成iframe的话

可以看到微信就直接不在里面展示给你页面白屏了

7 1

如果你更改appservice的webview的话微信还会给你各种alert弹框,反正应该就是不想让你分析他的代码

7 2 7 3

点击确定消都消不了只能重新重启编译了 有点小恶心啊

居然不让我们正大光明的看,那我们只能搞一些旁门左道来破坏了

我们第一步还是打开:微信开发者工具–》调试–》调试微信开发者工具
在控制台输入

document.getElementsByTagName(‘webview’)

可以看到对应的有4个webview,我们先要关注的是第一个webview因为你点开可以发现第一个对应的就是渲染层的webview

后面的几个可以先不关注,后续我们会详解

然后我们执行命令打开第一个webview:

document.getElementsByTagName(‘webview’)[0].showDevTools(true,null)

可以看到如图

8

现在我们就可以看到微信页面渲染层的页面结构了

(这里说明下本篇文章中文件里面的内容每一个文件的来源和用途,我都会在后续章节中讲解出来 因为里面涉及的内容过多 我怕放在一篇文章里会太长大家看了会厌烦,所以我会分为几篇来说明,后面的appservice 和 一些基础包和WAWebview.js WAService.js以及使用的同步api和请求在页面的appservice.js等等,在本篇中只会简单描述出来 不做过多讲解,后续会逐步更新)

上面的webview可以找到对应的页面层的结构,那么appservice要怎么找到呢?

其实最简单的我们直接在首页里面的控制台打document就可以直接看到展示的逻辑层代码

(我的做法是从写了微信的alert和基础库的一些文件都可以看到这个结构)

9

注意点在微信小游戏里面微信重写了window和document对象 所以不能直接按照我们平常操作页面那样使用

接下面我们看下微信小程序的基础库库文件

方法是我们在首页控制台里面输入openVendor()
我们可以看到弹出的文件系统,这里面对应的就是你选择本地的

详情==》调试基础库==》选择基础库版本

10

  • .wxvpkg文件就是每个基础库版本的包我们,解压这个包我们可以看到他的组成

  • wcc 可执行程序,用于将 wxml 转为 view 模块使用的js

  • wcsc 可执行程序,用于将 wxss 转为 view 模块使用的 css

.wxvpkg包里面这个基础库文件的WAWebview.js和WAService.js

对应这两个webview里面的js引用你可以仔细观察下

.wxvpkg文件解包后的格式

11

解压.wxvpkg格式包的代码地址github

对于wcc和wcsc源码现在没必要去研究他,但我们可以通过脚本劫持方法可以看到他运行了什么命令操作

这里告诉大家一个方法劫持他的运行命令

找到微信开发者工具wcc和wcsc的地方然后新建两个同名的脚本,然后把原文件从命名,然后重启微信开发者工具一定要重启不然不生效

wcc wcsca劫持脚本代码地址github

13

然后我们到首页控制台还是输入openVendor()可以看到输出的文件

13 2

从上面这个图就可以看出下面这个图里面我们可以认知到一些信息

  • 首次加载的时候wcc执行了-ds -d - xc…和-ds -d - cc…结构的命令可以看到微信首次把所有.wxml都执行了
  • 可以看到参数里面有个数字其实他对应的有几种.wxml文件形式向只存在.wxml和自定义组件等一些格式他是没计算在内的
  • -xc -cc 其实对应就是下面图两个逻辑层和渲染层里面的js方式

12

  • 我发现当我们修改一个.wxml里面一点改动的时候,微信又会全部从新编译执行这些命令很耗时这点其实可以改进的
  • 另一个微信开发者工具感觉做的不友好的地方是大于 500KB 的 javascript 文件不做给你做es6 转换和压缩,就算你设置了微信也不会给你转,可以在source里面的资源可以看出

wcc执行的命令最终生成的就是逻辑层和渲染层的$gwxc()方法里面的js代码,大家可以自己手动测试下就会发现

13 3

wxss生成的主要是渲染层eval()这一坨代码

14

本篇只是简单描述了一些关键文件的描述

后面我会对关键文件进行一一分析
描述下他具体做了什么,为什么用到它

下一篇会给大家带来渲染层和逻辑层的具体页面文件内容结构解析,以及webstock通信架构在微信开发者工具里面的运用
可以先给大家看下

15

其实他们之间的协调工作以及公开对外的wx.对象上面的api都是
通过websocket协议消息实现的

原文地址github感觉有用的话点个star支持一下

欢迎持续关注

如果写的对你有一点点帮助的话,就随便帮下小明同学 感谢大伙 !!!

一、 左下角点个赞再走吧,给博主一点关怀,可以让更多人看到

二、可以关注我的微信公众号「一起学Node」基于前后端NodeJs相关技术栈分享 交流 学习

实现微信小程序编译和运行环境系列(初始篇)相关推荐

  1. 实现微信小程序编译和运行环境系列 (进阶篇)

    动手实现微信小程序和小游戏编译打包和运行环境平台 (进阶篇) # 前言 距离上一篇初始篇过了一段时间,在初始篇里面主要分享了微信小程序工具 和微信小程序的文件组成,以及小程序架构的基本大纲和描述,看了 ...

  2. 微信小程序购物商城系统开发系列-工具篇

    微信小程序购物商城系统开发系列-工具篇 微信小程序开放公测以来,一夜之间在各种技术社区中就火起来啦.对于它 估计大家都不陌生了,对于它未来的价值就不再赘述,简单一句话:可以把小程序简单理解为一个新的操 ...

  3. 导入微信小程序显示未选择环境或未指定环境,解决办法

    导入微信小程序显示未选择环境或未指定环境 如下图所示: 解决办法:重新导入,选择云开发(需删掉以前的导入记录) 1.点击云开发申请通过 2.右键cloudfuncrions, 3.点击同步云函数列表 ...

  4. 微信小程序编译页面空白bug的原因

    目录 微信小程序编译页面空白的原因!!!!看看样式是不是写的scss, 缺少 scss语言 微信小程序编译页面空白的原因!!!!检查HTML是否缺少闭合标签 微信小程序编译页面空白的原因!!!!看看样 ...

  5. 微信小程序云函数开发环境 node.js的安装参考

    微信小程序云函数开发环境 node.js的安装参考 下载:nvm-windows 下载下图安装包,地址在: https://github.com/coreybutler/nvm-windows/rel ...

  6. 视频教程-30小时微信小程序从入门到精通课程-基础篇-微信开发

    30小时微信小程序从入门到精通课程-基础篇 8年IT开发经验,6年IT教育经验,喜欢把复杂逻辑用简单的表述传达给学生,传授编程知识,讲述生活故事 曹圣捷 ¥12.00 立即订阅 扫码下载「CSDN程序 ...

  7. wxwork和wx.qy判断企业微信小程序编译运行环境

    文章目录 前言 1.企业微信 2.个人微信 3.应用 前言 根据官方文档有两种方式可以判断: 1.方法一: 调用获取系统信息API[uni.getSystemInfoSync()],获取environ ...

  8. 微信小程序基础之开发环境搭建

    初心-杨瑞超个人博客诚邀您加入qq群(IT-程序猿-技术交流群):757345416 概述 开发小程序的第一步,你需要拥有一个小程序帐号,通过这个帐号你就可以管理你的小程序.跟随这个教程,开始你的小程 ...

  9. 微信小程序:本地开发环境和线上环境配置

    在开发微信小程序的时候,需要配置: 本地开发环境 体验预览环境 审核版环境 生产环境 为了简化环境配置,我只区分了两个环境 本地开发环境 生产环境/体验预览环境审核版环境生产环境 参考文档 基础 /系 ...

最新文章

  1. LVS 四层 TCP/UDP 负载均衡器
  2. 如何取消JS事件的派发——stopPropagation()
  3. 自助餐比喻秒懂微服务
  4. Mycat关键特性,什么是MYCAT,MYCAT监控,版本架构,长期规划2.0,Mycat高可用方案
  5. 初识ES-安装kibana
  6. bart使用方法_使用简单变压器的BART释义
  7. 8. Dropout and Strides For Larger Models
  8. 信息学奥赛一本通(2073:【例2.16 】三角形面积)
  9. 7 CO配置-控制-一般控制-维护版本
  10. Node mysql mvc vue_net MVC +Vue.js+Element UI 笔记
  11. 顺丰不顺、京东动荡,都是物流基因惹的祸?
  12. SAP License:关于未分摊差异的几种处理办法
  13. 构造方法是静态还是非静态?
  14. web.xml中/和/*的区别
  15. 系统学习机器学习之参数方法(三)
  16. 应用安全-安全设备-Waf系列-软Waf-安全狗(Safedog)
  17. python测试脚本实例-python脚本测试
  18. swf游戏保存进度_swf游戏
  19. Linux下四款Web服务器压力测试工具…
  20. Ubuntu安装nvm

热门文章

  1. PHP高级工程面试题汇总(2018.05)
  2. 纯C语言用Windows api写画函数图像
  3. 大牛们是如何开发 WordPress 主题的?
  4. autoit3转换php,AutoIt3处理字符串和数组
  5. 完全卸载ubuntu,原PC上已有win10(原是grub引导启动的)
  6. listbox删除报错_listbox里面项的删除方法
  7. 20xx绿色水墨创意学术报告PPT模版素材
  8. 分享27个自媒体必备工具,自媒体15天有4417,全程复制粘贴
  9. 2022 最新 Android 基础教程,从开发入门到项目实战【b站动脑学院】学习笔记——实战一:简易计算器
  10. 【收藏】75个很有用的开源移动工具