之前看到有大佬发了某麦网的apk加密接口分析那篇帖子,其中提到了用自动化工具开发出来的效果不太好,但是感觉自动化的不应该这么慢,于是尝试用autoxjs实现一个基于自动化的抢票工具,之前还用这个做过一个定时打卡的脚本,有需要的话我也可以分享一下。
0x01 环境
0x02 环境搭建
autoxjs环境搭建
原本的autojs作者已经不再维护了,autoxjs是民间维护版本,目前选择autoxjs。安装autox.js的apk,打开app
autojs.png (220.78 KB, 下载次数: )
下载附件
2023-6-2 15:00 上传
按上图设置好之后,如果你的设备有root的话点击设置,打开使用root权限自动启用服务,不然每次重启app都需要手动打开一次无障碍服务,不过好像有能通过脚本打开无障碍服务的方法,这个有兴趣的可以自己去找一下
autoxjs2.png (235.09 KB, 下载次数: )
下载附件
2023-6-2 15:00 上传
VScode环境搭建
官网上下载vscode,在插件商店里搜autoxjs,安装插件
企业微信截图_16856883503960.png (38.05 KB, 下载次数: )
下载附件
2023-6-2 15:00 上传
安装好后打开手机上的Autoxjs,打开“打开USB调试”
在电脑上的VScode里按Ctrl+Shift+p,点击开启服务并监听ADB设备
企业微信截图_16856888732253.png (27.08 KB, 下载次数: )
下载附件
2023-6-2 15:00 上传
成功开启后,手机上autoxjs中连接电脑选项会自动开启
企业微信截图_16856890302182.png (31.24 KB, 下载次数: )
下载附件
2023-6-2 15:00 上传
至此前期准备工作大概就做好了。
0x03 分析app
在这里打开悬浮窗,开启成功后会在屏幕左边出现一个小的悬浮窗图标
打开dm app,在这个页面点击autoxjs悬浮窗图标,再点击从上到下数第三个图标(蓝色),
image.png (17.85 KB, 下载次数: )
下载附件
2023-6-2 15:12 上传
有两个选项:布局范围分析、布局层次分析,选布局范围分析
企业微信截图_16856900776837.png (158.35 KB, 下载次数: )
下载附件
2023-6-2 15:14 上传
再当前页面点击控件就能获取到控件的信息
企业微信截图_16856903546654.png (58.13 KB, 下载次数: )
下载附件
2023-6-2 15:19 上传
接着就是对页面进行分析,然后根据流程一个个去判断页面和判断、点击按钮
大概的代码如下所示
[JavaScript] 纯文本查看 复制代码function damai() {
//五月天测试
var date = ["05-31", "06-01", "06-03"];
var prices = ["1555", "355", "1855", "555", "855", "1655"];
var viewer = ["111","zzz"];
var flag = true;
console.log("开始执行");
while (!id("tv_price_name").className("android.widget.TextView").textContains("票档").exists()) {
click("立即");
}
console.log(1);
while (true) {
for (var j = 0; j
[JavaScript] 纯文本查看 复制代码//根据控件文字点击
function clickMessage(message) {
if (!click(message)) {
console.error("点击" + message + "出错");
}
}
从订单详情页面到提交订单页面的时间(包括勾选多张票和多个观影人)大概需要0.5秒,这种方法是比人手抢要快的,但是肯定没有那位大佬通过发包的方式抢的快,而且稳定性方面还待确认。
企业微信截图_1685694667633.png (22.43 KB, 下载次数: 0)
下载附件
2023-6-2 16:45 上传
0x04 小结
本人也是这方面的新手,这个脚本本身算法和实现还有一些可以优化的地方,仅供大家参考,用自动化工具的优势算是比较好做各个app和机型的适配。还有一些人会遇到滑动条验证的问题(我本人还没遇到过),autoxjs提供了opencv的库可以用这个先识别滑块位置然后调用滑动事件,网上也有很多种解决方案,但是autoxjs使用无障碍的方式有时候会无法滑动滑动块,可能需要自己调用系统的api去写一个滑动事件。