破解极限滑动认证
from selenium import webdriver
from selenium.webdriver import ActionChains
from PIL import Image
import time
import random # 截取图片函数
def cut_image(driver):
driver.save_screenshot('image.png') img = driver.find_element_by_class_name('geetest_canvas_img') left = img.location['x']
upper = img.location['y'] right = left + img.size['width']
lower = upper + img.size['height'] image_obj = Image.open('image.png')
img_cut = image_obj.crop((left, upper, right, lower))
# img_cut.show()
return img_cut # 得到完整图片
def get_image1(driver): js_code = '''
var x = document.getElementsByClassName('geetest_canvas_fullbg')[0].style.display="block";
console.log(x)
''' time.sleep(0.2)
driver.execute_script(js_code) time.sleep(0.2)
img1 = cut_image(driver) return img1 # 得到缺口图片
def get_image2(driver):
js_code = '''
var x = document.getElementsByClassName('geetest_canvas_fullbg')[0].style.display="none";
console.log(x)
''' time.sleep(0.2)
driver.execute_script(js_code) time.sleep(0.2)
img2 = cut_image(driver) return img2 # 对比图片,得到滑动距离
def get_distance(img1, img2): # 小滑块右侧位置
start_location = 60 # 像素差
threshold = 60 for i in range(start_location, img1.size[0]):
for j in range(img1.size[1]): # 获得点(i,j)处的RGB像素值
rgb1 = img1.load()[i, j]
rgb2 = img2.load()[i, j]
r = abs(rgb1[0] - rgb2[0])
g = abs(rgb1[1] - rgb2[1])
b = abs(rgb1[2] - rgb2[2]) if not (r < threshold and g < threshold and b < threshold):
# 有误差,减去7
return i-7 def get_tracks(distance):
distance += 20
v0 = 0
a_list = [3, 4, 5]
t = 0.2
s = 0 # 向前滑动轨迹
forward_tracks = []
mid = distance * 3 / 5
while s < distance:
if s < mid:
a = a_list[random.randint(0, 2)]
else:
a = -a_list[random.randint(0, 2)] v = v0
stack = v * t + 0.5 * a * (t ** 2) # 每次拿到的位移
stack = round(stack)
s += stack
v0 = v + a * t forward_tracks.append(stack) back_tracks = [-1, -1, -2, -3, -2, -3, -2, -2, -3, -1] return {'forward_tracks': forward_tracks, 'back_tracks': back_tracks} def main(user, pwd): driver = webdriver.Chrome()
driver.maximize_window() try:
driver.implicitly_wait(10)
driver.get('https://account.cnblogs.com/signin?returnUrl=https%3A%2F%2Fwww.cnblogs.com%2F') username = driver.find_element_by_id('LoginName')
username.send_keys(user)
time.sleep(1) password = driver.find_element_by_id('Password')
password.send_keys(pwd)
time.sleep(1) submit = driver.find_element_by_id('submitBtn')
submit.click()
time.sleep(1) # 获取完整图片
img1 = get_image1(driver) # 获取缺口图片
img2 = get_image2(driver) # 获取移动距离
distance = get_distance(img1, img2) # 获取滑动轨迹,模拟人的滑动轨迹
tracks = get_tracks(distance) button = driver.find_element_by_class_name('geetest_slider_button')
ActionChains(driver).click_and_hold(button).perform() for forward_track in tracks['forward_tracks']:
ActionChains(driver).move_by_offset(xoffset=forward_track, yoffset=0).perform()
time.sleep(0.2) for back_track in tracks['back_tracks']:
ActionChains(driver).move_by_offset(xoffset=back_track, yoffset=0).perform() ActionChains(driver).move_by_offset(xoffset=-3, yoffset=0).perform()
ActionChains(driver).move_by_offset(xoffset=3, yoffset=0).perform()
time.sleep(0.1) ActionChains(driver).release().perform()
time.sleep(3)
finally:
driver.close() if __name__ == '__main__': user = '********'
pwd = '****************'
main(user, pwd)

 

python_07的更多相关文章

  1. python_07 函数作用域、匿名函数

    函数的作用域:无论在哪个地方调用函数,函数运行过程中的作用域只跟定义的时候有关,跟在哪个地方调用无关. name='alex' def foo(): name = 'linhaifeng' def b ...

随机推荐

  1. 『嗨威说』算法设计与分析 - 动态规划思想小结(HDU 4283 You Are the One)

    本文索引目录: 一.动态规划的基本思想 二.数字三角形.最大子段和(PTA)递归方程 三.一道区间动态规划题点拨升华动态规划思想 四.结对编程情况 一.动态规划的基本思想: 1.1 基本概念: 动态规 ...

  2. WSL捣鼓记——图形化(以emacs为例)

    前言 这学期开始学习linux,但笔记本装了双系统之后指纹识别会失效,开虚拟机又十分占据内存,于是乎基本需要使用linux的时候就用wsl,可奈何只有命令行界面,在需要使用图形软件(如emacs)的时 ...

  3. Mybaits 源码解析 (一)----- 搭建一个mybatis框架(MyBatis HelloWorld)

    源码分析之前先搭一个mybatis的demo,这个在看源码的时候能起到了很大的作用,因为在看源码的时候,会恍然大悟,为什么要这么配置,为什么要这么写.(老鸟可以跳过这篇) 开发环境的准备 创建mave ...

  4. 再不努力提高效率,小姐姐都被人追走了:K8S一键部署了解一下?

    随着互联网时代的不断发展,开发者可能会面临这样的困境:为了解决问题.提升开发效率而竭力研发出来的"创新",似乎削弱了他们在公司的重要程度,甚至取代了他们原先的地位.比如,在云原生时 ...

  5. webStrom快捷键快速创建React组件

    1. rcc + tab键 - - 用ES6模块系统创建一个React组件类 2. rccp + tab键 - - 创建一个带有PropTypes和ES6模块系统的React组件类 3. rcfc + ...

  6. .Net Core3.0依赖注入DI

    构建ASP.NET Core应用程序的时候,依赖注入已成为了.NET Core的核心,这篇文章,我们理一理依赖注入的使用方法. 不使用依赖注入 首先,我们创建一个ASP.NET Core Mvc项目, ...

  7. 【原】iOS开发进阶(唐巧)读书笔记(二)

    第三部分:iOS开发底层原理 1.Objective-C对象模型 1.1 isa指针 NSObject.h部分代码: NS_ROOT_CLASS @interface NSObject <NSO ...

  8. Kafka权威指南阅读笔记(第六章)

    Broker配置 Kafka可以同时拥有可靠的主题和非可靠的主题.非可靠的主题允许丢失. 复制系数 主题级别的配置参数是 replication.factor,在Broker级别则可以通过defaul ...

  9. 页面报错常用状态码总结(Http常见状态码)

    作为一个互联网开发人员对于一些服务器返回的HTTP状态的意思都必须是了如指掌的,只有将这些状态码一一弄清楚,工作中遇到的各种问题才能够处理的得心应手.好了,下面就让我们来了解一下比较常见的HTTP状态 ...

  10. 向现有URL末尾添加查询字符串参数

    向现有URL末尾添加查询字符串参数 xhr.open("get", "example.php?name1=value1&name2=value2", t ...