杭州五月天演唱会门票背后的黑灰产防范技术剖析

2,957 阅读3分钟

昨天五月天的票一出来,朋友圈一片腥风血雨,每个人都在哀嚎没有抢到票

image.png

现在大家满世界在抵制黄牛,但是就黄牛的手段,咱可差远了

image.png

“黄牛”还有一个别称是“黑灰产”,而黑灰产从业者具备较强的组织性、传播性和信息感知度。以营销活动脚本作弊场景为例,黑灰产滥用平台的各种营销活动机制,如新人奖励、用户裂变拉新奖励、签到奖励、秒杀优惠等,利用批量账号和自动化软件脚本(产生大量机器流量),绕过平台设定的限制规则,以积少成多的方式,大量地获取营销活动礼包, 然后将现金聚集到统一账号,或将红包、优惠券、电子券等以不同方式进行变现获利。而且黑灰产逐渐形成一条分工明确、合作紧密的黑灰产业链条。

image.png

实名制

目前主办方采取的主要手段是实名制,我们来看看一般实名制的手段是什么:

from flask import Flask, render_template, request, session

app = Flask(__name__)
app.secret_key = 'your_secret_key'

# 模拟已注册用户信息
registered_users = {
    'user1': {
        'name': '张三',
        'id_number': '1234567890'
    },
    'user2': {
        'name': '李四',
        'id_number': '9876543210'
    }
}

@app.route('/')
def home():
    return render_template('home.html')

@app.route('/buy_tickets', methods=['POST'])
def buy_tickets():
    # 获取用户输入的姓名和身份证号码
    name = request.form['name']
    id_number = request.form['id_number']

    # 检查用户信息是否匹配
    for user, info in registered_users.items():
        if info['name'] == name and info['id_number'] == id_number:
            # 用户信息匹配,执行购票逻辑
            # TODO: 在此处编写购票逻辑的代码
            return "购票成功!"

    # 用户信息不匹配,提示用户重新输入
    return "姓名和身份证号码不匹配,请重新输入!"

if __name__ == '__main__':
    app.run()

实名制购票要求购票者提供有效身份证明,并将购票者的姓名与身份证信息进行核对。这样可以确保每个人只能购买一定数量的门票,减少黄牛批量购票的可能性。

但是即使是这种情况,还是不能避免大部分人抢不到票。

验证码

另一个方式是在验证码阶段来卡黄牛。如前面的图所示,黄牛可能会使用物理手段来抢票,这个过程如果我们设置一个验证码的门槛,是可以刷掉大部分的机器流量的:

from flask import Flask, render_template, request, session
import random

app = Flask(__name__)
app.secret_key = 'your_secret_key'

# 生成验证码
def generate_captcha():
    captcha = ''
    for _ in range(6):
        captcha += str(random.randint(0, 9))
    return captcha

@app.route('/')
def home():
    # 生成验证码,并存储在session中
    captcha = generate_captcha()
    session['captcha'] = captcha
    return render_template('home.html', captcha=captcha)

@app.route('/buy_tickets', methods=['POST'])
def buy_tickets():
    # 获取用户输入的验证码
    user_captcha = request.form['captcha']
    # 获取存储在session中的验证码
    stored_captcha = session.get('captcha')

    if user_captcha == stored_captcha:
        # 验证码验证成功,执行购票逻辑
        # TODO: 在此处编写购票逻辑的代码
        return "购票成功!"
    else:
        # 验证码验证失败,提示用户重新输入
        return "验证码错误,请重新输入!"

if __name__ == '__main__':
    app.run()

排队购票系统

排队购票系统是整个购票系统的基础,让用户按照顺序进入购票页面。这样可以防止黄牛使用快速抢票软件或脚本,确保每个用户都有公平的机会购票。

from flask import Flask, render_template, request, session, redirect
import time

app = Flask(__name__)
app.secret_key = 'your_secret_key'

# 模拟排队队列
queue = []

@app.route('/')
def home():
    if 'user' not in session:
        # 用户未进入排队队列,将其加入队列
        session['user'] = str(time.time())
        queue.append(session['user'])
    return render_template('home.html')

@app.route('/buy_tickets', methods=['POST'])
def buy_tickets():
    # 检查用户是否在队列头部
    if 'user' in session and session['user'] == queue[0]:
        # 用户在队列头部,执行购票逻辑
        # TODO: 在此处编写购票逻辑的代码
        return "购票成功!"

    # 用户不在队列头部,重定向到主页等待
    return redirect('/')

if __name__ == '__main__':
    app.run()

结语

其实,粉丝们再怎么抗拒黄牛,黄牛都是“野火烧不尽,春风吹又生”,只能是主办方从技术手段上尽可能降低黄牛的风险,从而保证广大粉丝公平买票的权益。