叮咚自动下单 并发调用接口方式 多人实战反馈10秒以内成功 自动将购物车能买的商品全部下单 只需自行编辑购物车和最后支付即可
当前时间2022-04-14根据自身和身边朋友反馈正常下单,但不能保证每一个人都能成功下单,如果此程序完全不可用,我会更新到这个位置
非常重要 非常重要 非常重要 405问题解决方案(手机APP和小程序真机操作也无法进入购物车或无法下单),不保证完全有效,退出App账号重新登录,尝试刷新购物车和提交订单是否正常,如果正常则退出小程序重新登录后再抓包,替换UserConfig中的cookie和device_token。
购物车看不见商品一直提示当前人多拥挤,如果不是这个提示请参考注意事项中的第5项 。先给结论,不是封号,是叮咚服务器上你个人的购物车数据出现异常了,本人亲自经历正常人工App添加购物车,加之前购物车是好的,加着加着就进不去了购物车了,一直提示当前人多拥挤,通过一系列骚操作给救回来了。
- 进入购物车,注意看右上角有个删除按钮,如果是灰色的,下面首页分类购物车来回点再点点购物车里的我常买,一直来回切,直到切到右上角删除按钮变成绿色
- 点击删除按钮,再点击左下角全选,如果不出意外购物车里的东西就出来了
- 点击清空失效商品,再切换其他页面再进购物车
- 如果还没好继续重复1、2、3步骤,下次又会刷出来失效商品,一直清理清到没有失效商品就好了
- 此程序只用来帮助在上海急需买菜的程序猿,请勿商用,issues中非技术问题本人不参与也不会阻止大家讨论
- 叮咚的策略是6点和8点30更新当天配送时间,全天都有可能会上架货品,所以每天最佳抢菜时间是6点(当天第一轮允许下单),如果6点-8点30之间一直能配送那么8点30不会有任何变化,8点30主要是更新配送时间,只有当8点30之前无法配送的时候(当天第二轮允许下单)才需要在这个时间抢配送额度。总结6点抢库存和配送,8点30只抢配送
- 不要删除Application中的保护线程,此段代码控制程序并发执行时2分钟未下单自动终止,避免对叮咚服务器造成压力,也避免封号
- 根据反馈有不少人出现当天下单多次之后无法下单或无法支付的情况,请换号或隔一段时间再试
- 405问题解决方案(手机APP和小程序真机操作也无法下单),不保证完全有效,退出App账号重新登录,尝试刷新购物车和提交订单是否正常,如果正常则退出小程序重新登录后再抓包,替换UserConfig中的cookie和device_token。
- 接口如果出现405状态有以3种可能 1.偶发,无需处理 2.不要长时间运行程序,参考上面的第2点 3.一个账号下单数有时会有限制 参考上面的第3点
- 根据反馈有少部分人的站点是假库存,可能是怕大家闹事,开放购买之前能看到购物车里有,但是根本就不可能买到,第一秒下单瞬间很多东西就没了,我也是,几百块的购物车最后下单几十块,我同时用app人工操作了购物车确实是没货了,不是程序问题。
- 日期20220412我这个站点是6点开始陆续上东西,6点之前购物车没有东西可以买
- 有反馈说用PC端小程序的UserAgent无法下单,如果你是用PC端小程序抓包不要覆盖UserConfig中的UserAgent
非Java开发很多 加一点新手教学 老手直接忽略
- intellij idea 新手教学:下载路径 https://www.jetbrains.com/idea/download/#section=windows 下载好使用30天试用版即可 祈祷30天内能回归正常生活
- jdk 8 新手教学:下载路径 https://www.oracle.com/java/technologies/downloads/#java8-windows 搜索Java SE Development Kit 8u321找到合适你系统和cpu的版本 一键安装
- maven 新手教学:可用idea内置maven 什么都不用操作
- 打开idea - (file 如果是第一次安装跳过此项直接能看到open) - open - 项目文件夹 - 等待右下角maven构建进度条
- 新手不要自己新建一个项目在往项目里加文件 直接使用方式4 等待进度条结束即可 如果不小心叉掉了进度条,删掉项目,重新拉,重复步骤4(有其他方法,但新手很难理解就不推荐了)
对java完全不熟悉的来个快速入门
public class UserConfig { //UserConfig是类名 下面文档中说的执行Application就是类名
//一个类只能有一个main方法 也就是启动方法 在idea中右键此文件Run就是执行这个类 如果该类中没有main方法则没有Run这个选项 项目中的Api类就没有main方法
public static void main(String[] args) {
}
}
- 通过Charles(我截图和教程是Charles,用Charles会更方便对比)等抓包工具抓取微信中叮咚买菜小程序中的接口信息中的用户信息配置到UserConfig.java中,比如openId、userId,详情见下截图,此操作每个用户只需要做一次。注意事项:其中有一个参数叫station_id,headers和body中都有,一定要确认抓包时你的站点信息设置是对的(非常重要 非常重要 非常重要),进入小程序后左上角确认站点信息后再抓包
- 运行UserConfig.java获取addressId填入addressId变量并确认站点信息是否正确,如果执行显示用户过期则检查参数少配或配错,重点关注headers中ddmc-device-id、cookie、ddmc-uid ,body中uid、open_id、device_token
- 将需要买的菜自行通过APP放入购物车
- 5-8执行模式根据使用需求自选
- 测试模式(单线程): 执行ApplicationTest低峰期单次下单
- 人工执行(多线程并发):设置Application中的policy变量1并运行,如果当前购车有商品并有配送时间则会在10秒内执行成功
- 时间触发(多线程并发):设置Application中的policy变量2或3并运行,当系统时间到达5点59分30秒或8点29分30秒自动执行,如果购买成功将播放一分钟的提示音(请确保电脑外放无静音)
- 哨兵模式(单线程):设置Sentinel中最小下单金额并运行,当金额超过设置金额时尝试下单,请注意此模式下不并发,所以在6点和8点30左右的高峰期可能会存在长时间无法正常下单,高峰期买菜使用6或者7策略,如果购买成功将播放一分钟的提示音(请确保电脑外放无静音)
- 等待程序结束,如果成功下单请在5分钟内付款,否则订单会取消,用手机打开叮咚买菜app-我的订单-待支付-点击支付
- 每次抢之前跑一下UserConfig中的main方法确认登录状态是否准确,如果状态不对则重新抓包更新UserConfig数据
- 如果想用自己的号帮别人下单,只需要手动在APP中设置一下默认地址再运行UserConfig 获取到addressId和stationId进行替换
- 购物车无可购买商品(时间触发和哨兵模式会持续执行)
- 下单成功
- 用户登录信息失效
小程序已经有PC版了,手机进入小程序右上角3个点->在电脑中打开即可,送上一个参考文章https://blog.csdn.net/z2181745/article/details/123002569 比手机抓包方便太多。
注意事项
- Charles安装和配置好后再打开或重新打开电脑端叮咚小程序,如果在之前打开可能会抓不到
- 如果使用电脑端小程序抓包,则不要去碰手机微信里的叮咚小程序,否则session会失效,反过来也一样,其他操作在app上操作不影响,但不能同时在两个端的小程序操作,互斥
- 确保电脑和手机没有打开vpn(公司的或者梯子)
- 打开微信小程序中的叮咚买菜,通过电脑抓包软件抓取信息填入代码中,在token不失效的情况下可以一直使用
- 也可以使用电脑端小程序进行抓包会比手机方便很多
- 在开放购买前选择商品到购物车
- 等待下单成功后去待支付订单页面支付
- 运行UserConfig获取addressId并填入变量addressId
- 开放购买前1分钟运行Application,前30秒左右会获取基本信息直到看到提交订单失败的信息则代表基本信息获取完毕等待开放时间一到即可成功
虽然我家吃的很多,但是时间长了也受不了这几天每天早上起来抢菜,手都点抽经了都买不到,看着购物车里的菜越来越少心急如焚,作为程序员只能靠自己的双手了,吃完午饭开干,晚上6点成功下单
- 抓app的包没抓到
- 抓小程序的包可以,但是小程序无法做登录,拿不到open id,所以只能通过自行抓包解决。另看到请求参数中有一些签名字段,心想麻烦哟
- 准备研究如何签名,解包微信小程序,初步研究签名相关代码,搞不定就去研究app hook,但那耗费精力太大,留着当后手
- 先写一个获取地址的请求,发现那几个看着像签名的参数可以不用传,省了一大笔精力,应该一开始就用Charles的breakpoint删除参数再repeat尝试无签名是否可访问,被唬住了,早知道就可以省略步骤3
- 梳理下单需要的参数和步骤,数据量非常庞大,眼睛都看晕了,需要细心
- 看到下单成功很开心,这就是乐趣
最后希望疫情早日结束大家伙都能吃上饭
- 新增自动勾选购物车
- 优化请求量过大和持续时间过长被网关拦截提示
- 执行UserConfig时新增站点信息确认,如站点信息错误将导致购物车在手机上看有货程序执行无货或无法下单
- 叮咚更新了异常返回数据结构,修改异常日志输出
- 修复无法使用优惠券的问题
- 修复明明显示有配送信息但下单时报该时间段不能配送的问题
- 新增平常时间段哨兵模式(长间隔单线程),设置最小下单金额,成功下单后会播放一分钟的铃声,请将电脑音量打开到合适的音量
- 新增5点59和8点29两个时间触发程序(并发),如需使用 请设置Application中的policy变量,成功下单后会播放一分钟的铃声,请将电脑音量打开到合适的音量
- 新增并发时保护程序,默认并发执行2分钟,避免封号和对叮咚服务器造成的压力
- 提交订单的间隔时间拉长后下单效率明显降低,30秒才成功,改回原配置
这个图有时候会挂,直接从项目里面看也一样,就是路径image/headers.jpeg 和 body.jpeg 对应到UserConfig中的headers和body方法里的参数
用了的全部秒抢,我自己傻逼了,为了提交github,收货地址id在运行的时候忘记填了,跑了几分钟才后知后觉,随即补上了失败时的返回信息。
本项目为 GPL3.0 协议,请所有进行二次开发的开发者遵守 GPL3.0协议,并且不得将代码用于商用。