Compare commits

...

6 Commits

Author SHA1 Message Date
zhao-zg
34952a36e4
更新 login.py 2025-04-11 19:40:47 +08:00
zhao-zg
aac7ea01d6
更新 login.py 2025-04-11 19:30:20 +08:00
zhao-zg
9740b85671
更新 login.py 2025-04-11 19:26:34 +08:00
zhao-zg
e97cdb2867
更新 login.py 2025-04-11 19:19:43 +08:00
zhao-zg
72f91fb3b8
优化代码
滑块优化
2025-04-11 18:54:41 +08:00
zhao-zg
63329ba727
Update login.py
修复滑块
2025-04-11 17:17:28 +08:00

View File

@ -612,9 +612,11 @@ async def sendSMSDirectly(page):
while True:
if await page.xpath('//*[@id="small_img"]'):
await verification(page)
elif await page.xpath('//*[@id="captcha_modal"]/div/div[4]/button'):
elif await page.xpath('//*[@id="captcha_modal"]/div/div[3]/button'):
if await verification_shape(page) == "notSupport":
return "notSupport"
else:
break
@ -652,9 +654,11 @@ async def sendSMS(page):
while True:
if await page.xpath('//*[@id="small_img"]'):
await verification(page)
elif await page.xpath('//*[@id="captcha_modal"]/div/div[4]/button'):
elif await page.xpath('//*[@id="captcha_modal"]/div/div[3]/button'):
if await verification_shape(page) == "notSupport":
return "notSupport"
else:
break
@ -798,18 +802,38 @@ async def verification(page):
distance = await get_distance()
await page.mouse.move(box["x"] + 10, box["y"] + 10)
await page.mouse.down()
await page.mouse.move(
box["x"] + distance + random.uniform(3, 15), box["y"], {"steps": 10}
)
await page.waitFor(
random.randint(100, 500)
)
await page.mouse.move(
box["x"] + distance, box["y"], {"steps": 10}
)
await page.waitFor(
random.randint(400, 1000)
)
steps=50
start_x = box["x"] # 直接使用box的x作为起点
start_y = box["y"] # Y轴固定不变
end_x = start_x + distance
for i in range(steps):
t = i / steps
# ==== 三阶贝塞尔曲线控制 ====
if t < 0.7:
# 加速阶段:贝塞尔控制点偏向终点
phase_ratio = t / 0.7
x_ratio = 3 * (phase_ratio**2) - 2 * (phase_ratio**3) # 三阶缓动
current_x = start_x + distance * 0.8 * x_ratio
noise = random.uniform(-2, 2) # 允许较大初始抖动
else:
# 减速阶段:精准收敛至终点
phase_ratio = (t - 0.7) / 0.3
x_ratio = 0.8 + 0.2 * (1 - (1 - phase_ratio)**3) # 三阶缓入
current_x = start_x + distance * x_ratio
noise = random.uniform(-1, 1) * (1 - t) # 扰动衰减至0
# 应用噪声(距离越大抖动幅度越大)
current_x += noise
# 移动鼠标Y轴始终不变
await page.mouse.move(current_x, start_y, steps=2)
# 双重校准终点(应对任何残余误差)
await page.mouse.move(end_x, start_y, steps=2)
await page.waitFor(random.randint(100,300))
await page.mouse.up()
logger.info("过滑块结束")