手把手教你用python抢京东大额神券

一、背景介绍



我们经常能看到京东上有满200减100之类的大额神券,但是当自己激动的等在电脑旁,手拿鼠标、眼盯屏幕,等着倒计时慢慢临近,期待抢到自己喜爱的优惠券,然而最终得到的往往是“券已抢完”

手把手教你用python抢京东大额神券

为了弥补手速的缺憾,今天我教大家如何用python抢优惠券,让你的“手速”提高数十倍。


二、抓包分析

首先,我用浏览器抓包发现,抢券过程是通过get请求实现的:

手把手教你用python抢京东大额神券

请求参数为:

手把手教你用python抢京东大额神券

主要就是key值,它是每个优惠券的标志参数,我们有3种方法可以找到它:

  1. 在原网页中:
手把手教你用python抢京东大额神券

data-key的值即为上述的key值,我们可以用selenium从原网页获取key值,这种方法只能用selenium操控浏览器获得key值。

2.抓包获取传递key值的数据接口:


手把手教你用python抢京东大额神券


接口地址:

<code>https://a.jd.com/indexAjax/getCouponListByCatalogId.html?&catalogId=134&page=1&pageSize=9&_=1588425128493/<code>

每页返回9个优惠券信息,page代表页码,pageSize代表返回数量。

三、python模拟请求

Key值找到了,下面就可以用requests模拟抢券了,python模拟请求代码如下:


<code>/<code>
<code>import requestsheader={'User-Agent':'Mozilla/5.0 (Windows NT 6.1; Win64; x64; rv:64.0) Gecko/20100101 Firefox/64.0?',    'Referer':'https://a.jd.com/',    'Cookie': '写入你的cookie'}key = '0271DFD6890D3B60ACB8BA8A9E49BEB17FE8E6323A36834B63FE69E95D38088EFCFCC41CEDA463F657AC10A29B05CD8C80317528B28221B996820855DF2962B519E4BCD69F2FAD2A6A0C71D95C08EC37657F57BE5FF35205CD6EB7B98375482F'session = requests.session()url1 = 'https://passport.jd.com/loginservice.aspx?&method=Login&_=1588432511753'response1 = requests.get(url1, headers=header)/<code>
<code>url2 = 'https://a.jd.com/indexAjax/getCoupon.html?callback=jQuery708242&key={0}&type=1&_=1588433465288'.format(key)header={'User-Agent':'Mozilla/5.0 (Windows NT 6.1; Win64; x64; rv:64.0) Gecko/20100101 Firefox/64.0?',    'Referer':'https://a.jd.com/',    'Cookie': '写入你的cookie'}​response2 = requests.get(url2, headers=header)/<code>

我把代码分成了两部分,领券是由第二段代码实现的,那么为什么要用第一段呢?

其实这是一种反爬措施,就是领券之前要先进行验证,让服务器知道这是哪个用户在领券,在之前的文章中有详细介绍:细说小白学python爬虫过程中常见的反爬措施及解决思路(干货)



第一段代码的返回结果为:


<code>{"Identity":{"Unick":"小笨鸟","Name":"jd_100000000","IsAuthenticated":true}}/<code>


第二段代码的返回结果为:

<code>jQuery708242({"code":"999","success":true,"message":"领券成功"})/<code>

将这两段代码合成一块就是这次抢大额优惠券的代码了。


以上介绍的只是如何用python实现普通优惠券的领券过程,但我们要抢的券都是有倒计时的,所以,要加循环并检测的功能,并在倒计时快结束了的时候循环运行程序:

<code>while True:    response2 = requests.get(url2, headers=header)    response2.encoding='utf-8'    if '领券成功' in response2.text:        break/<code>


最后,展示一下批量领取优惠券的过程,代码如下:

<code>#批量领取优惠券代码# 公众号【python的爬虫与数据分析之路】import requestsimport jsonheader={    'User-Agent':'Mozilla/5.0 (Windows NT 6.1; Win64; x64; rv:64.0) Gecko/20100101 Firefox/64.0',    'Referer':'https://a.jd.com/'}cookie={    'Cookie':'写入你的cookie'}for i in range(3):#获得key值    url='https://a.jd.com/indexAjax/getCouponListByCatalogId.html?callback=jQuery8020514&catalogId=134&page={0}&pageSize=9&_=1588487277055'.format(i+1)    response = requests.get(url, headers=header)    items=json.loads(response.text[14:].replace(')', ''))    for key in items['couponList']:        key=key['ruleKey']        header = {'User-Agent': 'Mozilla/5.0 (Windows NT 6.1; Win64; x64; rv:64.0) Gecko/20100101 Firefox/64.0?',                  'Referer': 'https://a.jd.com/',                  'Cookie': '写入你的cookie'}        session = requests.session()        url1 = 'https://passport.jd.com/loginservice.aspx?&method=Login&_=1588432511753'        response1 = requests.get(url1, headers=header)        url2 = 'https://a.jd.com/indexAjax/getCoupon.html?callback=jQuery708242&key={0}&type=1&_=1588433465288'.format(            key)        header = {'User-Agent': 'Mozilla/5.0 (Windows NT 6.1; Win64; x64; rv:64.0) Gecko/20100101 Firefox/64.0?',                  'Referer': 'https://a.jd.com/',                  'Cookie': '写入你的cookie'}        response2 = requests.get(url2, headers=header)        response2.encoding = 'utf-8'        print(response2.text)​/<code>


除了不能领的,都显示领取成功了:

手把手教你用python抢京东大额神券

学会这项技能,再也不怕抢不到券了!

本文所述的代码已上传至【python的爬虫与数据分析之路】后台,请输入优惠券获取。另外,程序中出现的问题可以私聊我:


分享到:


相關文章: