zoukankan      html  css  js  c++  java
  • python_07

    破解极限滑动认证
    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)
    
    
    
     
  • 相关阅读:
    MySQL0902作业(待巩固)
    Mysql之懵逼的一天
    sql查询语句详解
    MySQl语句总结
    0831练习作业(待纠正)
    0824MySQL
    Python数据分析——正则表达式
    Python数据分析——Beautiful Soup
    Python数据分析——requests使用
    Excle常用函数——Rank(统计排名)
  • 原文地址:https://www.cnblogs.com/zhanglei97/p/11062470.html
Copyright © 2011-2022 走看看