python_day7爬蟲之selenium

1.破解極驗(yàn)滑動(dòng)驗(yàn)證

from selenium import webdriver
from selenium.webdriver import ActionChains
from PIL import Image
import time
import random

# 截取圖片函數(shù)
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

# 對(duì)比圖片,得到滑動(dòng)距離
def get_distance(img1, img2):

    # 小滑塊右側(cè)位置
    start_location = 60

    # 像素差
    threshold = 60

    for i in range(start_location, img1.size[0]):
        for j in range(img1.size[1]):

            # 獲得點(diǎn)(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

    # 向前滑動(dòng)軌跡
    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)

        # 獲取移動(dòng)距離
        distance = get_distance(img1, img2)

        # 獲取滑動(dòng)軌跡,模擬人的滑動(dòng)軌跡
        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)
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容