从 Github Release 下载对应系统的最新版本
此版本在叮咚的多次升级下已不可用, 不再维护
程序启动后,可以在浏览器打开 http://localhost:9999/notify 测试推送通知是否正常
最好用一个账号抢菜, 另一个账号捡漏下单和监听运力
如果无法找到所列出的请求,请参见后文 iOS 设备 Charles 抓包帮助
1、在iOS设备上启动叮咚买菜APP
2、完成登录
3、启动Charles并完成抓包配置(需要配置SSL抓包)
4、点击“购物车”并刷新
5、在请求中找到https://maicai.api.ddxq.mobi/cart/index
6、右击该请求,选择Export Session,保存到项目 session 文件夹下,文件类型请选择JSON Session File (.chlsj)
接续 获取 Session 第三步
4、点击“我的”并刷新
5、在请求中找到https://sunquan.api.ddxq.mobi/api/v1/user/detail
6、左击该请求,选择Contents选项卡,在下半部分选项卡中选择JSON Text视图
7、找到 user_info 下的 im_secret 字段,复制其值到配置文件中
- iphone上通过App Store安装Stream
- 打开叮咚买菜微信小程序和Stream, Stream点击"开始抓包"
- 回到叮咚买菜微信小程序, 商品加入购物车并结算提交(无需付款)使得小程序发起网络请求
- 回到Stream停止抓包并查看抓包历史, 点击按域名, 会看到 maicai.api.ddxq.mobi 这个域名下的请求
感谢群友 邱建忠 提供的前端网页
感谢群友 hhhhg~ 提供的教程 安卓抓包方法及Windows端小白教程.docx
QQ群: 60768433 (golang & rust & flutter & 区块链 交流学习)
base_concurrency // 除了提交订单的其他请求并发数 默认为1
submit_concurrency // 最后提交订单的并发数 默认为2
snap_up // 抢购 0关闭, 1 六点抢, 2 八点半抢, 3 六点和八点半都抢
advance_time // 抢购提前进入时间 单位:秒 默认为15
pick_up_needed // 闲时捡漏开关 false关闭 true打开 在抢购高峰期之外的时间捡漏 使用时需同时打开监听器
monitor_needed // 监听器开关 监听是否有运力
monitor_success_wait // 成功监听(发起捡漏或通知)之后的休息时间 单位:分钟 默认为10
monitor_interval_min // 监听器调用接口的最小时间间隔 单位:秒 默认为25 (防止接口调用过于频繁, 被叮咚风控)
monitor_interval_max // 监听器调用接口的最大时间间隔 单位:秒 默认为35
notify_needed // 通知开关 发现运力时或捡漏成功时的通知 使用需同时打开监听或捡漏
audio_needed // 播放音频开关 在订单提交成功后播放音频
GET 请求 localhost:9999/set
浏览器中打开 http://localhost:9999/set?monitor_needed=1&monitor_interval_min=10&monitor_interval_max=20 , 并设置想要修改的参数
参数 | 名称 | 说明 |
---|---|---|
base_concurrency | 基础并发数 | 除了提交订单的其他请求并发数, 默认为1 |
submit_concurrency | 提交并发数 | 最后提交订单的并发数, 默认为2 |
snap_up | 抢购模式 | 0 关闭, 1 六点抢, 2 八点半抢, 3 六点和八点半都抢 |
advance_time | 抢购提前时间 | 提前一段时间执行一些预备任务(如获取购物车) 单位:秒 默认为15 |
pick_up_needed | 捡漏开关 | 0 关闭 1 打开 |
monitor_needed | 监听开关 | 0 关闭 1 打开 |
monitor_success_wait | 监听成功后休息时间 | 监听成功(发起捡漏或通知)之后的休息时间 单位:分钟 默认为10 |
monitor_interval_min | 监听的最小时间间隔 | 监听器调用接口的最小时间间隔 单位: 秒 |
monitor_interval_max | 监听的最大时间间隔 | 监听器调用接口的最大时间间隔 单位: 秒 |
notify_needed | 通知开关 | 0 关闭 1 打开 |
audio_needed | 播放音频开关 | 0 关闭 1 打开 |
push_plus | 通知用户 | 安卓和苹果都可使用 PushPlus 推送通知 |
bark | 通知用户(仅苹果) | 苹果使用 Bark 推送通知 |
例子
api | 说明 |
---|---|
localhost:9999/set?bark=xxx,yyy | 添加需要通知的用户, 第一个是自己的 barkID, 其他为需要通知到的朋友(只能通知与你同属一个叮咚发货站点的用户) |
localhost:9999/set?snap_up=1 | 六点抢购 |
localhost:9999/set?pick_up_needed=1 | 打开捡漏,在抢购高峰期之外的时间捡漏(需同时打开监听器) |
localhost:9999/set?monitor_needed=1 | 打开监听器 在抢购高峰期之外的时间监听是否有运力 |
localhost:9999/set?notify_needed=1 | 打开推送通知(需同时打开监听器) |
localhost:9999/set?monitor_success_wait=5 | 设置推送时间间隔(防止太过频繁) |
localhost:9999/set?bark=first,second&pick_up_needed=1&monitor_needed=1¬ify_needed=1&monitor_success_wait=5
打包到release目录下
make build # 默认打包为macOS darwin-amd64 Intel处理器
make build ARCH=arm64 # macOS M1处理器
make build OS=linux # linux
make build OS=windows # windows
将 config.example.json 重命名为 config.yml
确保与程序同一目录中包含 config.yml
在终端中执行
./dingdong
在CMD中执行
./dingdong.ext
本项目为 GPL3.0 协议,请所有进行二次开发的开发者遵守 GPL3.0 协议,并且不得将代码用于商用。