android 反编译 百度经验,从一次失败的微信小程序抓包、反编译经历中学习反思...

本文详细介绍了如何尝试通过反编译和抓包工具对微信小程序进行分析,包括使用npm、安卓模拟器、微信开发者工具和反编译软件的过程。尽管最终因微信云开发的保护措施未能成功获取到接口数据,但作者分享了整个尝试过程,增加了对微信小程序安全措施的了解。
摘要由CSDN通过智能技术生成

某天看到群里某个朋友说某小程序抓不到包,我忽然就来了兴趣,我也试着分析了下这个小程序,名字我就不说了,本着我我的兴趣分析学习的目的。javascript

我用安卓和IOS,以及charles和fiddler都试了,还真的抓不到包,返回的都是以下图的数据,红色标注区域就是微信返回的接口,可是尾部的数字和字母每次都是随机出现的,并且也并无直接可见的数据,都是加密的字段,如图可见php

ae59a3e0ad6188afbbb162781088f6ca.png

这就有点意思了,而这个小程序的广告地址我都直接抓到了,但就是数据没抓到,很奇怪,而后忽然脑子里蹦出来一个想法,反编译试试?css

说干就干html

须要用到工具:

npm

安卓模拟器

微信开发者工具

反编译工具

1.安装npm

去这个网站下载npm:java

而后安装就一直点【next】就好了git

测试是否安装好:在终端里运行以下命令:github

e24271ddf69c3618ef644454794067f9.png

2.安装安卓模拟器

安卓模拟器有夜神,mumu,genymotion,感受都差很少,大的区别没有,夜神、mumu、genymotion都有windows和mac版,只有些小的区别web

我这里使用的是夜神npm

安装也是一路点next就好了

3.安装微信开发者工具

安装了这个工具才能打开反编译后的小程序源码,并本地预览加载

一样的也是一路下一步,跟着提示操做就好了

安装完了以后,须要去微信开发者平台注册一个开发者帐号 https://mp.weixin.qq.com/

e3f04e7b5a914311b26e3180.html

登录以后,选到以下的【基本设置】,而后跟着操做就好了

37271efe372662a3418e581cabf32a60.png

4.安装反编译工具

b8ee329f2f5298a0285f1d6706619d70.png

可是文件已为空:

06d58c8bcd6ffe78ea483af7c42e7695.png

很骚,这个具体缘由不知道,我后来想了下也想明白了,应该是微信方为了安全保护本身平台的小程序,因此跟做者作了沟通吧,也或者做者本身以为不太好,本身把项目下架了,不过我仍是在网上找到一个,网址的话我想了好久,仍是不贴出来了,有兴趣的朋友本身去找吧

准备工做都完毕了,开始配置环境

配置环境

1.模拟器里安装软件

直接在应用市场(模拟器自带有应用市场)里下载  【微信】,和 【RE管理器】

e7b6720d236643f7b2766de871c4fd80.png

2.将小程序反编译工具解压,放到本身想要的目录

就是刚才下载的wxappUnpacker,解压到任意目录,我这里直接解压的C盘,临时使用,这个步骤太过简单,掠过

3.安装npm软件包:

注意这个步骤建议进入你解压后的wxappUnpacker文件夹下操做,后面的反编译命令就能够直接用相对路径来执行,更方便一点

我这里由于以前已经安装过,因此就随意了。

1).在以前,先用npm初始化  npm  init

583ad338950bc26135f15ac04e23ba7e.png

2). 安装以下的软件:

注意有的文章用的是 npm install esprima -g,这个是在全局安装的意思,这种就看你本身怎么选择了,我我的建议直接安装在当前目录便可

npm install esprima

npm install css-tree

npm install cssbeautify

npm install vm2

npm install uglify-es

npm install js-beautify

npm install escodegen

7567b3d39290557befce7073b03422c0.png

3).在安装js-beautify会报以下错:

bf0d9671355da45bbeaa75d26b0e90a5.png

使用以下命令,清楚缓存:

9841d90f7358154b249dde2d0e2325df.png

再次安装便可:

8e7dcb79f0c90092248575f914a5ef7b.png

4).最后再安装escodegen

da830f8c8982808c490ea104584877dd.png

5)测试环境

我这里已经进入了wxappUnpacker目录里操做了

b9807ef210e2e7949be435bea8d0e9a8.png

导出微信小程序文件

1).打开安卓模拟器,打开微信,而后启动目标小程序,必定到打开下,由于要打开过的才会下载小程序文件存储到本地

2).退出微信,打开模拟器里的RE管理器

第一次打开RE文件管理器,会有这个选项,选择以下便可

ae867429b625340fcd7be41fc484fa8d.png

3). 从RE管理器里找到以下目录:

/data/data/com.tencent.mm/MicroMsg

这个目录下找那个文件夹名为一长串的字母加数字的文件夹即为一个微信用户的目录,通常状况下就只有1到3个这种文件夹,一个一个打开看看就知道了

d71fa9c3aa00e0bc65db55c676f81803.png

4).进入用户目录后,再进入以下红线标注出的目录,就会看到后缀为wxapkg的文件,这种文件就是微信小程序的包文件了

b85e106ba420f7bbb91400a41b46ebea.png

可是这种文件也会有多个,因此哪一个是你的目标对象也不知道,一样的,一个一个试,就几个文件,总有一个是对的

5).指着这个文件,鼠标左键长按,而后右上角会出现三个点,点那三个点,出现下图标注区域选项,选择压缩这个文件

9d0d0facd87a1ad3ccc91a4dfdcbd643.png

6).压缩完了后,它提示你是否要查看,点查看

e85a530d0d48aea748c4d93668ee7d41.png

会自动跳到下图的目录,而后,下面的zip文件就是刚才压缩的文件了,我这里由于以前试了几个,压缩了好几回,因此有好几个压缩包,这个对本篇博客来讲没影响

dcc2fd6e55e1a0769df18412a8b890a9.png

7).一样的,鼠标左键长按,而后点右上角的三个点,选择下图的区域,发送,其实就是将文件导出去

0eeb17aac69204990f7c2d41492a5cf8.png

发送给微信好友,或者你再在模拟器里装个QQ,发送给QQ好友也行,反正目的就是把这个压缩包导出去,你用什么方法均可以

cfe3ff20f24ce0c5f9c13b87ad708764.png

d1b5184672ed363b3c1d123fdb4a590a.png

a9767faa4af4d37239feb7ef5a79fa40.png

说到这里,补充一点:若是你在刚开始打开微信(如上图),从微信里打开小程序,无法打开时,能够先换一个号把这个小程序分享给你,而后在模拟器里点击下就能够打开小程序了,我用夜神模拟器时,就须要下拉准备启动小程序时模拟器直接闪退的状况

开始反编译

1).把从安卓模拟器里导出来的小程序文件,放到一个指定目录,我这里就直接放在wxappUnpacker里的 ,这个就看你本身了,放不放wxappUnpacker目录无所谓,反正你方便操做就行

dd7f555f588962ed3018b155e298a944.png

2).执行反编译命令

node wuWxapkg.js  xxx(小程序包名)

5252909e3e3ca6de49fe031779d5951b.png

3).若是有以下错:

c9898ec6a5f879491566f7667845bd3a.png

修改wuWxss.js文件的以下位置,

functionrunOnce(){for(let name inrunList)runVM(name,runList[name]);

}

改为以下:

functionrunOnce() {for (let name inrunList) {//console.log(name, runList[name]);

var start = `var window = window || {}; var __pageFrameStartTime__ = Date.now(); var __webviewId__; var __wxAppCode__={}; var __mainPageFrameReady__ = function(){}; var __WXML_GLOBAL__={entrys:{},defines:{},modules:{},ops:[],wxs_nf_init:undefined,total_ops:0}; var __vd_version_info__=__vd_version_info__||{};

$gwx=function(path,global){if(typeof global === 'undefined') global={};if(typeof __WXML_GLOBAL__ === 'undefined') {__WXML_GLOBAL__={};

}__WXML_GLOBAL__.modules= __WXML_GLOBAL__.modules ||{};

}`;

runVM(name, start+ " \r\n" +runList[name]);

}

}

如图:

092a25c63d903948ae9ce14e51861f6b.png

再次反编译:

1e8d4e71f9fcf5a0137349a672d06227.png

看到最后那个File done,即表示反编译完毕 ,这时候同目录下会出现同名的文件夹:

d429e653c30349948104aab5ad15da68.png

5).把这个文件夹用微信开发者工具打开,导入项目:

没有AppID能够暂时点【使用测试号】

a0bd432d66be0009580daa7be9eaa4d2.png

而后就会自动加载小程序

a4467d055b4d012dd8fe709c0e9185ec.png

5).便可开始你的代码分析了

可是,我准备分析的目标小程序,以下图,请求数据失败,由于这个小程序是用的微信云开发制做的

什么是微信云开发

就是制做的小程序没有本身的后端服务,由微信团队在2018年推出的服务,微信平台提供简单的后台管理,你只须要把数据传到云平台,而后调取微信云开发里本身定义好的函数或者接口就好了,说白了就是一个小程序不须要后端就能够作出来,跟咱们以往认知的不同,但也有一个弊端,就是若是你想看到更多的后台管理数据可能就没戏了,好比你想根据用户数据做进一步的分析就别想了,有关微信云开发详细的本身百度吧

因此,我拿到的接口是微信云开发的接口 :   wx.cloud.callFunction.getJobList,也就根本没法分析出这个接口的整个机制,请求什么数据,返回什么数据了,想都别想了,拿都拿不到数据。这种状况我查了下资料,没戏,也有可能我看漏了,反正我鼓捣了好一下子,得出的结论就是没戏,而且我尝试用微信的开发者AppID修改源码,提示我不是这个小程序的开发者,无法修改,因此是完全没戏了

9c38b1501e365d145333b27b9e4d9908.png

确实是挺失败的一次抓包分析,不过我以为经过此次,仍是涨见识了,微信方这方便作得确实不错,不得不佩服啊

相信有朋友确定要问,你既然都是失败了为何还要把这个事写成博客发出来呢?

这个缘由就是,一来是经过此次反编译,我我的而言确实是涨见识了,若是让您也学到了,那么天然更是好事,二来是我以为这个没有什么丢不丢脸的事,失败了就是失败了,毕竟人生总不会都如意的,算是记录下我此次的经历

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值