原神抢码,米游社抢码免费分享

本文章仅供学习使用-侵权请联系删除_2023年2月19日20:30:06

本来在30抽抢不过的我偶然在刷到了一个dy的直播间,看到主播在抢码上号帮忙抽卡我就决定扫码试试,在直播间内使用了两部手机互相扫码在扫了一下午的码后发现根本抢不到二维码心态崩溃后我就想着写一个脚本来帮我抢码(本人py小白),终于在又白忙活了一早上的后终于决定抱着学习的态度写一个程序来帮我进行抢码

原理讲解

1.进行屏幕区域的截图(用来获取二维码)

2.将获取到的二维码进行解析

3.将解析后的内容截取出ticket

# 抢码开始
def Request(ticket):
    conn = http.client.HTTPSConnection("api-sdk.mihoyo.com")
    payload = json.dumps({
        "app_id": 4,
        "device": "",
        "ticket": ticket
    })
    headers = {}
    conn.request("POST", "/hk4e_cn/combo/panda/qrcode/scan", payload, headers)
    res = conn.getresponse()
    data = res.read()
    data = json.loads(data.decode("utf-8"))
    retcode = data["retcode"]
    return retcode
在这里插入代码片# 确认登陆
def ConfirmRequest(ticket):
 
    conn = http.client.HTTPSConnection("api-takumi.miyoushe.com")
    payload = ''
    headers = {
        'DS': '',
        'cookie': '',
        'x-rpc-client_type': '',
        'x-rpc-app_version': '',
        'x-rpc-sys_version': '',
        'x-rpc-channel': '',
        'x-rpc-device_id': '',
        'x-rpc-device_fp': '',
        'x-rpc-device_name': '',
        'x-rpc-device_model': '',
        'Referer': ' https://app.mihoyo.co'
    }
    conn.request("GET", "/auth/api/getGameToken?uid=0000000",
                 payload, headers)
    res = conn.getresponse()
    data = res.read()
    # print(data.decode("utf-8"))
 
    data = json.loads(data.decode("utf-8"))
    token = data["data"]["game_token"]
 
    conn = http.client.HTTPSConnection("api-sdk.mihoyo.com")
    payload = json.dumps({
        "app_id": 4,
        "device": "",
        "payload": {
            "proto": "Account",
            "raw": f"{{\"uid\":\"0000000\",\"token\":\"{token}\"}}"
        },
        "ticket": ticket
    })
    headers = {
        'DS': '',
        'cookie': '',
        'x-rpc-client_type': '',
        'x-rpc-app_version': '',
        'x-rpc-sys_version': '',
        'x-rpc-channel': 'xiaomi',
        'x-rpc-device_id': '',
        'x-rpc-device_fp': '',
        'x-rpc-device_name': '',
        'x-rpc-device_model': '',
        'Referer': ' https://app.mihoyo.com',
        'Content-Type': 'application/json'
    }
    conn.request("POST", "/hk4e_cn/combo/panda/qrcode/confirm",
                 payload, headers)
    res = conn.getresponse()
import cv2
from pyzbar.pyzbar import decode
import pyzbar.pyzbar as pyzbar
import numpy as np
from PIL import ImageGrab
import time
import tkinter as tk
import threading
import re
import http.client
import json
 
# 显示框框 启动线程
 
 
def my_function():
    import juxing
 
 
my_thread = threading.Thread(target=my_function)
my_thread.start()
 
 
# 获取坐标
root = tk.Tk()
win_width = 300
win_height = 300
screen_width = root.winfo_screenwidth()
screen_height = root.winfo_screenheight()
x_pos = (screen_width // 2) - (win_width // 2)
y_pos = (screen_height // 2) - (win_height // 2)
 
 
# 设置扫描区域左上角的坐标和宽高
left, top, width, height = x_pos, y_pos, win_width, win_height
right = left + width
bottom = top + height
 
 
# 创建窗口并设置窗口名称
cv2.namedWindow("QR Code Scanner", cv2.WINDOW_NORMAL)
cv2.resizeWindow("QR Code Scanner", win_width, win_height)
 
 
# 抢码开始
def Request(ticket):
    conn = http.client.HTTPSConnection("api-sdk.mihoyo.com")
    payload = json.dumps({
        "app_id": 4,
        "device": "",
        "ticket": ticket
    })
    headers = {}
    conn.request("POST", "/hk4e_cn/combo/panda/qrcode/scan", payload, headers)
    res = conn.getresponse()
    data = res.read()
    data = json.loads(data.decode("utf-8"))
    retcode = data["retcode"]
    return retcode
 
 
# 确认登陆
def ConfirmRequest(ticket):
 
    conn = http.client.HTTPSConnection("api-takumi.miyoushe.com")
    payload = ''
    headers = {
        'DS': '',
        'cookie': '',
        'x-rpc-client_type': '2',
        'x-rpc-app_version': '2.46.1',
        'x-rpc-sys_version': '9',
        'x-rpc-channel': '',
        'x-rpc-device_id': '',
        'x-rpc-device_fp': '',
        'x-rpc-device_name': '',
        'x-rpc-device_model': '',
        'Referer': ' https://app.mihoyo.co'
    }
    conn.request("GET", "/auth/api/getGameToken?uid=0000000",
                 payload, headers)
    res = conn.getresponse()
    data = res.read()
    # print(data.decode("utf-8"))
 
    data = json.loads(data.decode("utf-8"))
    token = data["data"]["game_token"]
 
    conn = http.client.HTTPSConnection("api-sdk.mihoyo.com")
    payload = json.dumps({
        "app_id": 4,
        "device": "",
        "payload": {
            "proto": "Account",
            "raw": f"{{\"uid\":\"0000000\",\"token\":\"{token}\"}}"
        },
        "ticket": ticket
    })
    headers = {
        'DS': '',
        'cookie': '',
        'x-rpc-client_type': '2',
        'x-rpc-app_version': '2.46.1',
        'x-rpc-sys_version': '9',
        'x-rpc-channel': ' xiaomi',
        'x-rpc-device_id': '',
        'x-rpc-device_fp': '',
        'x-rpc-device_name': '',
        'x-rpc-device_model': '',
        'Referer': ' https://app.mihoyo.com',
        'Content-Type': 'application/json'
    }
    conn.request("POST", "/hk4e_cn/combo/panda/qrcode/confirm",
                 payload, headers)
    res = conn.getresponse()
    # data = res.read()
    # print(data.decode("utf-8"))
 
 
while True:
    # 截取指定区域的屏幕截图
    screenshot = cv2.cvtColor(
        np.array(ImageGrab.grab(bbox=(left, top, right, bottom))),
        cv2.COLOR_BGR2RGB
    )
 
    # 将截图转换为灰度图像
    gray = cv2.cvtColor(screenshot, cv2.COLOR_RGB2GRAY)
 
    # 尝试使用pyzbar库识别二维码
    codes = decode(gray, symbols=[pyzbar.ZBarSymbol.QRCODE])
 
    # 如果找到了二维码,输出其内容
    if codes:
        print(codes[0].data.decode())
        pattern = r"ticket=([a-f0-9]+)"
        match = re.search(pattern, codes[0].data.decode())
        # 正则请求地址
        if match:
            start_time = time.time()
            # 进入抢码
            retcode = Request(match.group(1))
            end_time = time.time()
            if retcode == 0:
                # 计算代码执行时间
                elapsed_time = end_time - start_time
                #  输出执行时间
                print("抢码成功耗时 %.3f 秒" % elapsed_time)
                # 确认登陆
                ConfirmRequest(match.group(1))
                time.sleep(1)
 
    # 等待一段时间再继续扫描
    time.sleep(0.05)
 
    # 在窗口中显示截图
    cv2.imshow("QR Code Scanner", screenshot)
 
    # 检查是否按下了键盘上的任意键
    if cv2.waitKey(1) != -1:
        break
# 关闭窗口
cv2.destroyAllWindows()
 
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 3
    评论
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值