破解 京東登錄滑塊驗證


# 第一次使用會有進度條加載,直接可運行
# 直接上源碼
import asyncio
import random
import cv2
from pyppeteer import launch
from urllib import request


# 滑塊的缺口距離識別
async def get_distance():
img = cv2.imread('image.png', 0)
template = cv2.imread('template.png', 0)
res = cv2.matchTemplate(img, template, cv2.TM_CCORR_NORMED)
value = cv2.minMaxLoc(res)[2][0]
distance = value * 278/360
return distance


async def main():
browser = await launch({
'headless': False,
     # 需要設置一個路徑
        'userDataDir': r'E:\mj',
        'args': ['--no-sandbox', '--window-size=1366,768'],
})
page = await browser.newPage()
await page.setViewport({'width': 1366, 'height': 768})
await page.goto('https://passport.jd.com/login.aspx')
await page.waitFor(1000)
await page.click('div.login-tab-r')
await page.waitFor(1000)

# TODO 模擬人工輸入用戶名、密碼 輸入自己的賬號密碼
await page.type('#loginname', '*****',
{'delay': random.randint(60, 121)})
await page.type('#nloginpwd', '*****',
{'delay': random.randint(100, 151)})
await page.waitFor(2000)
await page.click('div.login-btn')
await page.waitFor(3000)
# 模擬人工拖動滑塊、失敗則重試
while True:
if await page.J('#ttbar-login'):
print('登錄成功!')
await page.waitFor(6000)
break
else:
image_src = await page.Jeval('.JDJRV-bigimg >img', 'el => el.src')
request.urlretrieve(image_src, 'image.png')
template_src = await page.Jeval('.JDJRV-smallimg >img', 'el => el.src')
request.urlretrieve(template_src, 'template.png')
await page.waitFor(3000)
el = await page.J('div.JDJRV-slide-btn')
box = await el.boundingBox()
await page.hover('div.JDJRV-slide-btn')
distance = await get_distance()
await page.mouse.down()
await page.mouse.move(box['x'] + distance + random.uniform(30, 33), box['y'], {'steps': 30})
await page.waitFor(random.randint(300, 700))
await page.mouse.move(box['x'] + distance + 29, box['y'], {'steps': 30})
await page.mouse.up()
await page.waitFor(3000)


asyncio.get_event_loop().run_until_complete(main())



免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM