Honesty
文章33
标签33
分类4

文章归档

上海咖啡文化周之薅瑞幸羊毛

上海咖啡文化周之薅瑞幸羊毛

首先声明:本人没有恶意利用这个漏洞去谋利,只是测试用了那么一次。不提倡大家去做这种违法行为,本文仅供学习

💡 最近瑞幸在搞活动,每天免费送 10000 份咖啡,我是个狂热喝咖啡的人儿,今天最后一天来整个活儿,点开瑞幸咖啡小程序主页,banner 栏轮播图中有一张海报入口,操作一通下来,果然,没抢到。
手速不够快不是主要原因,手指操作延迟 + 系统页面跳转耗时加起来到 http 发出就已经耽误了 1 -2 秒钟了,这个时间才是关键,本文从技术角度探讨下怎么在最小成本比如几分钟内,实现一个小工具,来解决这个问题。

202306021513432.png

首先需要一个抓包工具,iphone 手机可以用 stream, 有几个注意点:

1、默认安装后是无法抓取 https 类型的,需要在设置里进行相关配置:

如果您要抓取 HTTPS 的请求,需要先启动抓包,然后安装 CA 证书后,去设置-通用-关于-证书信任设置 里信任 CA,才可以查看请求的内容。

image

2、注意小程序里面哦(原生的可能抓不到),拿到的接口名如下:

https://mkt.lkcoffee.com/ladder/capi/resource/m/promo/activity/send

stream 提供了 curl 的拷贝,将其复制并导入到 postman 中。

202306021523307.png

postman 导入&复现

点击 import 按钮,在弹窗中选择 raw text 将复制的 curl 字符串粘贴进去,点击确认,就成功的将 这个 http 接口导入到了 postman 中,尝试点击 send 按钮,发现拿到了正确的响应,验证了该接口已经可以正常使用。

202306021522744.png

image

自动化脚本?

其实到这一步,已经实现了目标,点击 send 直接发送请求,大大提升了抢到的概率,如果你还想更进一步,那么可以尝试将其封装成 自动化脚本,来实现定时、自动、重复发送;

点开右侧代码块,选择语言,假设选择 python(也可以任意选择你擅长的语言),然后就自动生成 python 版本的可执行代码片段,我们就在这个基础上拓展功能;

202306021521797.png

示例代码如下:


import requests
import time

url = "http://example.com"  # 将此处的 URL 替换为你要请求的地址payload = {}
headers = {
	#将 postman 中的headers 复制过来}

start_time = "09:59:55"  # 设置开始请求的时间end_time = "10:00:30"  # 设置结束请求的时间def make_request():
    response = requests.get(url, headers=headers, data=payload)
    if "成功" in response.text:
        print("响应内容:", response.text)
        raise SystemExit  # 中断程序while True:
    current_time = time.strftime("%H:%M:%S", time.localtime())
    if current_time >= start_time and current_time <= end_time:
        make_request()
    time.sleep(1)  # 每秒检查一次当前时间

将其保存到本地并通过 python 指令来执行,就可以运行了。

总结

用今天的午睡时间,写了这篇文,以瑞幸的营销活动为例子,带你感受了下技术的魅力,其中涉及到了抓包、自动化脚本、定时任务、请求策略、stream 和 postman 等知识;

本文作者:Honesty
本文链接:https://docs.hehouhui.cn/archives/lkcoffee-shanghai-coffee-activities-20230602.html
版权声明:本文采用 CC BY-NC-SA 3.0 CN 协议进行许可
×