找回密码
 会员注册
查看: 33|回复: 0

Python脚本Python自动大麦网抢票,准点原价秒杀演唱会门票,拒绝黄牛交易!从我做起!!!1

[复制链接]

10

主题

0

回帖

31

积分

新手上路

积分
31
发表于 2024-9-9 18:08:57 | 显示全部楼层 |阅读模式
文章目录前言一、分析购票过程二、Selenium模拟浏览器操作三、逆向工程:抢票接口总结前言你是否错过了周杰伦的票,最近又没抢到五月天的票,不要太难过,今晚有张学友的票,后天还有张杰的票,加油哦!Python配套案例源码、资料点击领取福利为了帮助你在激烈的抢票竞争中获得更大的成功机会,本文将介绍抢票软件的实现原理以及我所了解的一些抢票方式。但是,请不要过度将希望寄托于抢票软件,它有时也不灵,经过我的验证,即使你用到了抢票软件,也不一定能抢到票。票务平台会经常调整反爬策略打击爬虫行为,如果希望抢票软件保持较高的成功率,是需要开发者针对票务平台的打击策略作出逻辑调整,这个成本是很高的,所以你能随手获得的抢票软件很大概率是抢不到票的或者说是不安全的。在调研过程发现一个有意思的点“黄牛的票从来不是抢来的”。相关规定,面向市场公开销售的营业性演出门票数量,不得低于核准观众数量的70%。而剩下的那30%,即非公开销售的票,则是黄牛票的主要来源,也叫渠道票。这里面涉及主办方对热门票和冷门票的售票策略,黄牛在这链条中扮演着重要的角色,只要演唱会门票的二级市场不会消失,黄牛就永远不会消失,对于市场本身来说,愿意花更多钱买黄牛票的人,一定是更有需求的人,黄牛不过是市场调节的人格化。一、分析购票过程现在无论是买火车票、飞机票、演唱会票基本都是使用电子支付网上购票,之后得到一张电子票凭证,进场前打印纸质票或者闸机核销票据二维码进场,那么我们从用户角度看下,一次完整的购票过程是什么样。用户的购票流程:首先用户登录票务APP搜索爱豆的门票,点击查看门票详情,然后选择场次和票档。等待抢票倒计时,才能进入到下一个页面;倒计时结束后,开抢按钮被点亮,用户进入下一步选择观演人,确认信息后选择付款方式提交订单;如果手速足够快、运气足够好,抢到了票就会唤起所选的支付方式APP提示付款;如果没有抢到则会提示拥堵,跳转到票档选择页面。下面,我将这个图补充一下,思考下哪些步骤是用户可以提高出票成功率的关键时间节点:很显然,用户在倒计时之前看不到的页面就是竞争手速的关键时机,当这个开抢按钮被倒计时点亮的一瞬间,要以最快的速度点击到达隐藏页面,然后选中观演人,通常使用默认的支付方式,最后提交订单。一旦订单被提交成功,就说明锁定了席位抢到了票。如果用户在规定的时间内未付款,该席位会重新流入票池,捡漏的人就可以抢到。到这里,我们知道了购票流程和提高抢票成功率的突破口,人的手速肯定没有机器快,接下来介绍下两种常用的技术抢票方案。二、Selenium模拟浏览器操作在使用Chrome浏览器,用户可以使用鼠标滑动、按键点击以及键盘输入,作为信号输入设备向浏览器传达指令,浏览器收到指令后执行渲染。这里提到的SeleniumWebDriver是对浏览器提供的原生API进行封装,使用这套API可以操控浏览器的开启、关闭,打开网页,操作界面元素,控制Cookie。简单说就是,可以通过写代码的方式来自动实现用户鼠标和键盘信号的输入。这么一来,可以做的事就非常多了。下面是一个简单脚本,它首先打开chrome浏览器输入google的网址,等待5秒,浏览器网页打开后,找到输入框输入”ChromeDriver“,然后模拟点击搜索按钮,就能看到浏览器上搜索的结果。importtimefromseleniumimportwebdriverfromselenium.webdriver.common.byimportBybrowser.get("https://www.google.com")time.sleep(5)#查找元素search_box=browser.find_element(By.NAME,'q')#模拟按键输入search_box.send_keys('ChromeDriver')#搜索框模拟回车search_box.submit()time.sleep(5)#关闭所有窗口browser.quit()12345678910111213141516回到抢票的主题上来,我们可以使用这种技术能力,写一个Python脚本,在本地机器上执行起来。脚本内容是在指定的时间打开浏览器,打开票务网页,然后自动模拟用户选择观影人然后自动提交订单。(在这里我原本很想做一个演示视频,理解起来更直观,奈何时间精力有限,这里就不详细介绍SeleniumWebDriver开发环境配置,感兴趣的可以继续深挖。)三、逆向工程:抢票接口什么是逆向?即通过技术手段对票务APP的通讯流量抓包,定位获取票档、提交订单的关键请求解密https流量,然后分析解密流量数据。我们继续回到这张图,仔细观察会发现,用户查看门票详情以及选择票档等一些动作都是APP上完成的都是提前加载好的,而真正决定用户抢票的是“提交订单”这个关键请求。如果我们可以将这个这个请求的流量抓到,然后分析其参数构造规则,就可以编写程序自动发送请求了。下面抓包示例,选取了一个门票,抓包获取了其票档信息。以此类推,抓包下单接口观察其参数构成,编写程序模拟用户请求。#等待开售defwait_for_buy():#抢购时间start_timestamp=1686475533#当前时间current_timestamp=int(time.time())whilecurrent_timestamp>start_timestamp:#开始购买place_order()123456789'运行运行这里简要介绍了下实现思路和方向,不展开逆向过程的细节。具体实现没有这么简单的,有攻击方必然有防守方,票务方为了保障平台方利益,势必会定义打击策略,例如,我们会看到验证码从文字到图片再到滑块验证的一个迭代过程。技术方面是一个问题,法律方面也是一个问题,所以全当一次攻防演练的学习,不要伤害票务方的利益。总结生活有时很操蛋,我们会感到力不从心,但请守住你的热爱,别让它被挫折磨灭”。祝大家买票的时候都能以正常价格抢到自己心仪的演唱会门票~↓↓↓加下方名片找我,直接拿源码还有案例↓↓↓
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 会员注册

本版积分规则

QQ|手机版|心飞设计-版权所有:微度网络信息技术服务中心 ( 鲁ICP备17032091号-12 )|网站地图

GMT+8, 2025-1-10 13:41 , Processed in 0.496798 second(s), 25 queries .

Powered by Discuz! X3.5

© 2001-2025 Discuz! Team.

快速回复 返回顶部 返回列表