python 使用opencv处理selenium的图片滑块验证码问题

一、获取图片地址:

 

1.方法一:使用selenium通过获取接口返回请求获取图片地址:

#获取背景图和缺口图地址;此方法比较复杂,需要知道验证图片接口的请求地址;通过接口响应获取验证码图片地址:  此方法使用时,需要大家将接口相关信息改为自己产品的接口及json数据信息。

此方法为通过selenium获取到页面访问的网络请求,在所以网络请求中获取到对应图片验证码接口的请求,获取到该请求的的requestid,在通过requestid获取到对应接口的响应结果;

使用json数据过滤获取出图片的地址;

代码如下: 

def getpicpath():
    request_log = browser.get_log('performance')
    print(request_log)
    for i in range(len(request_log)):
        message = json.loads(request_log[i]['message'])
        message = message['message']['params']
        # .get() 方式获取是了避免字段不存在时报错
        request = message.get('request')
        if (request is None):
            continue
        url = request.get('url')
        if ("https://c.dun.163.com/api/v2/get?referer" in url):
            # 得到requestId
            print(message['requestId'])
            # 通过requestId获取接口内容
            content = browser.execute_cdp_cmd('Network.getResponseBody', {'requestId': message['requestId']})
            # print(content)
            data = json.loads(content['body'][18:-2])
            # print(data)
            url1 = data['data']['bg'][0]
            url2 = data['data']['front'][0]
            print(url1)#1为背景图
            print(url2)#2为缺口图
            break
    return url1,url2

2.方法二:通过selenium获取元素属性获取图片地址:获取后将图片存储;

# 获取验证码中的图片

def get_image(driver):
    # 获取背景图url
    block_img_url = driver.find_element_by_xpath('/html/body/XXXXXXXXXXXX/div/div[1]/img[1]').get_attribute('src')
    print(block_img_url)
    # 获取移动块url
    target_img_url = driver.find_element_by_xpath('/html/body/XXXXXXXXXXXX/div/div[1]/div/div[1]/img[2]').get_attribute('src')
    print(target_img_url)
    try:
        img_b = requests.get(block_img_url).content
        with open('background.png', "wb") as f_b:
            f_b.write(img_b)
        img_t = requests.get(target_img_url).content
        with open('target.png', "wb") as f_t:
            f_t.write(img_t)
        return True
    except:
        return False

二、图片存储:

def save_img(block_img_url,target_img_url):
    """
    保存图片
    :param block_img_url: 图片url
    :return:
    """
    try:
        img_b = requests.get(block_img_url).content
        with open('background.png', "wb") as f_b:
            f_b.write(img_b)
        img_t = requests.get(target_img_url).content
        with open('target.png', "wb") as f_t:
            f_t.write(img_t)
        return True
    except:
        return False

三、计算图片滑动像素距离:重点功能,这里是通过OpenCV实现的。

#计算图片滑动像素点


def show(name):
    '''展示圈出来的位置'''
    cv2.imshow('Show', name)
    cv2.waitKey(0)
    cv2.destroyAllWindows()

def _tran_canny(image):
    """消除噪声"""
    image = cv2.GaussianBlur(image, (3, 3), 0)
    return cv2.Canny(image, 50, 150)


def detect_displacement(img_slider_path, image_background_path):
    """detect displacement"""
    # # 参数0是灰度模式
    image = cv2.imread(img_slider_path, 0)
    template = cv2.imread(image_background_path, 0)
    # 寻找最佳匹配
    res = cv2.matchTemplate(_tran_canny(image), _tran_canny(template), cv2.TM_CCOEFF_NORMED)
    # 最小值,最大值,并得到最小值, 最大值的索引
    min_val, max_val, min_loc, max_loc = cv2.minMaxLoc(res)
    top_left = max_loc[0]  # 横坐标
    # 展示圈出来的区域
    x, y = max_loc  # 获取x,y位置坐标
    w, h = image.shape[::-1]  # 宽高
    cv2.rectangle(template, (x, y), (x + w, y + h), (7, 249, 151), 2)
    # show(template)
    return top_left

四、拖动滑块移动:

1.匀速滑动;

def drag_btn(distance):
    # 拖动按钮的div, 得到滑块的初始位置,并进行异常处理
    try:
        dragBtn = browser.find_element_by_xpath("/html/body/div[4]/div[2]/div/div/div[2]/div/div[2]/div[2]/span")
        print('开始拖动滑块。')
    except Exception as e:
        print("get button failed: ", e)
    ActionChains(browser).move_to_element(dragBtn).perform()
    ActionChains(browser).click_and_hold(dragBtn).perform()
    while distance > 5:
        ActionChains(browser).move_by_offset(5, 0).perform()
        time.sleep(10 / 1000)
        distance -= 5
    ActionChains(browser).release().perform()

2.模拟人员操作滑动:

计算人为滑动的移动速率;每0.01秒的移动像素距离list;

# 这个是用来模拟人为拖动滑块行为,快到缺口位置时,减缓拖动的速度,服务器就是根据这个来判断是否是人为登录的。

# 这个是用来模拟人为拖动滑块行为,快到缺口位置时,减缓拖动的速度,服务器就是根据这个来判断是否是人为登录的。
def get_tracks(dis):
    v = 0
    m = 0.3
    # 保存0.3内的位移
    tracks = []
    current = 0
    mid = dis * 4 / 5
    while current <= dis:
        if current < mid:
            a = 2
        else:
            a = -3
        v0 = v
        s = v0 * m + 0.5 * a * (m ** 2)
        current += s
        tracks.append(round(s))
        v = v0 + a * m
    return tracks


def drag_btn_personify(distance):
    # 原图的像素是276*172,而网页的是340*212,图像放大了。  340/276 = 1.231884058
    double_distance = int(distance+10)
    tracks = get_tracks(double_distance)
    # 由于计算机计算的误差,导致模拟人类行为时,会出现分布移动总和大于真实距离,这里就把这个差添加到tracks中,也就是最后进行一步左移。
    tracks.append(-(sum(tracks) - double_distance))
    # 拖动按钮的div, 得到滑块的初始位置,并进行异常处理
    try:
        dragBtn = browser.find_element_by_xpath("/html/body/div[4]/div[2]/div/div/div[2]/div/div[2]/div[2]/span")
        print('开始拖动滑块。')
    except Exception as e:
        print("get button failed: ", e)
    ActionChains(browser).move_to_element(dragBtn).perform()
    ActionChains(browser).click_and_hold(dragBtn).perform()
    for track in tracks:
        ActionChains(browser).move_by_offset(track, 0).perform()
        time.sleep(10 / 1000)
    ActionChains(browser).release().perform()

如有问题可联系QQ:334650037

  • 1
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
### 回答1: Python可以使用第三方库Selenium处理滑块验证码Selenium是一个自动化测试工具,可以模拟浏览器的行为。我们可以用它来模拟用户操作,例如拖动滑块处理滑块验证码的步骤如下: 1. 首先安装Selenium库,可以使用pip命令进行安装:pip install selenium 2. 导入Selenium库:from selenium import webdriver 3. 创建一个浏览器对象,推荐使用Chrome浏览器:browser = webdriver.Chrome() 4. 打开网页,使用get方法打开验证码页面:browser.get("滑块验证码网页的URL") 5. 定位滑块和背景图片的元素,通过id、class或者其他属性进行定位,例如:slider = browser.find_element_by_xpath("//div[@class='slider']")、background = browser.find_element_by_xpath("//div[@class='background']") 6. 获取滑块和背景图片的位置信息,可以使用元素的属性获取:slider_location = slider.location、background_location = background.location 7. 计算滑块需要移动的距离,一般是滑块的位置减去背景图片的位置,例如:distance = slider_location['x'] - background_location['x'] 8. 导入ActionChains库:from selenium.webdriver.common.action_chains import ActionChains 9. 使用ActionChains库中的drag_and_drop_by_offset方法来拖动滑块,将距离作为参数,例如:ActionChains(browser).drag_and_drop_by_offset(slider, distance, 0).perform() 10. 提交表单,完成滑块验证,例如:submit_button = browser.find_element_by_xpath("//input[@type='submit']")、submit_button.click() 通过以上步骤,可以使用PythonSelenium库来处理滑块验证码。需要注意的是,由于每个滑块验证码的实现方式可能不同,上述步骤可能需要根据具体的情况进行调整和优化。 ### 回答2: Python 可以使用 Selenium 库来处理滑块验证码。以下是一个简单的示例代码: ```python from selenium import webdriver from selenium.webdriver.common.action_chains import ActionChains # 创建 Chrome 浏览器实例 driver = webdriver.Chrome() # 打开目标网站 driver.get("目标网站的URL") # 定位滑块滑动区域元素 slider = driver.find_element_by_xpath("滑块元素的XPath") slider_area = driver.find_element_by_xpath("滑动区域元素的XPath") # 获取滑块的初始位置和滑动区域的宽度 initial_position = slider.location['x'] slider_width = slider_area.size['width'] # 计算需要滑动的距离,这里可以根据具体情况来调整 target_position = initial_position + slider_width * 0.8 # 创建 ActionChains 对象并执行滑动动作 action = ActionChains(driver) action.click_and_hold(slider).move_by_offset(target_position, 0).release().perform() # 若需要等待滑块验证结果的加载完成,则可以添加等待代码,例如等待某个元素的出现 # 关闭浏览器实例 driver.quit() ``` 以上代码仅提供了一个基本的处理滑块验证码的框架,具体应用时可以根据实际情况进行调整和扩展。如有需要,可以参考 Selenium 文档进行更深入的学习和使用。 ### 回答3: Python可以使用selenium库与浏览器进行交互,以处理滑块验证码。下面是一种可能的解决方法: 1. 导入selenium库和相应的浏览器驱动程序。例如,如果使用Chrome浏览器,需要下载ChromeDriver并将其路径配置到系统环境变量中。 2. 使用selenium库打开目标网页,并找到滑块验证码图片滑块元素。 3. 使用selenium库的`get_attribute()`方法获取滑块验证码图片的URL,并使用`requests`库下载保存到本地。 4. 使用OpenCV库读取滑块验证码图片,并使用图像处理技术分割滑块背景和滑块。 5. 将滑块背景图像与目标块的图像进行比对,找出滑块相对于滑块背景图像的偏移量。 6. 使用selenium库的`ActionChains`类,模拟鼠标点击并拖动滑块元素,将滑块拖动到正确的位置。 7. 使用`selenium`库的`execute_script()`方法执行JavaScript代码,模拟鼠标释放,完成验证码的拖动。 8. 验证验证码是否通过,可以通过判断页面元素是否发生变化或者出现登录成功的提示进行判断。 需要注意的是,滑块验证码的设计可能不同,因此具体的处理方法可能会有所不同。以上是一种简单的处理滑块验证码的方法,具体的实现还需要根据实际情况进行调整。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值