返回顶部
首页 > 资讯 > 后端开发 > Python >如何使用python登录带弱图片验证码的网站
  • 686
分享到

如何使用python登录带弱图片验证码的网站

2023-06-14 05:06:32 686人浏览 薄情痞子

Python 官方文档:入门教程 => 点击学习

摘要

小编给大家分享一下如何使用python登录带弱图片验证码的网站,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!图片验证码一般都通过加干扰线、粘连或扭曲等方式来增加强

小编给大家分享一下如何使用python登录带弱图片验证码的网站,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!

图片验证码

一般都通过加干扰线、粘连或扭曲等方式来增加强度。

如何使用python登录带弱图片验证码的网站

登陆

我们选择一个政务网站(图片验证码的强度较低)。

点击个人用户登录

访问网站首页以后我们发现需要先点击个人用户登陆,且元素没有name、id登标识不好获取,所以我们直接执行里面的onClick方法

如何使用python登录带弱图片验证码的网站

如何使用python登录带弱图片验证码的网站

# 新建selenium浏览器对象,后面是geckodriver.exe下载后本地路径browser = WEBdriver.Firefox()url = 'Http://xxx.Gov.cn/'# 浏览器访问登录页面browser.get(url)# 等待3s用于加载脚本文件browser.implicitly_wait(3)# 点击个人登陆browser.execute_script('showpersonlogin();')

获取图片验证码

我们可以通过save_screenshot截图,然后找到验证码元素,获取元素位置然后在截图的基础上裁剪出验证码。

# 找到图片验证码元素img = browser.find_element_by_id('imGCode')location = img.locationsize = img.sizeleft = location['x']top = location['y']right = left + size['width']bottom = top + size['height']# 按照验证码的长宽,切割验证码image_obj = loginPage.crop((left, top, right, bottom))image_obj.save('code.png')

如何使用python登录带弱图片验证码的网站

如何使用python登录带弱图片验证码的网站

识别并登陆

由于该网站的验证码比较简单可以直接用pytesseract模块的image_to_string方法

orcCode = pytesseract.image_to_string('code.png')# 输入用户名username = browser.find_element_by_id('personaccount')username.send_keys('账号')# 输入密码passWord = browser.find_element_by_id('personpassword')password.send_keys('密码')# 输入验证码code = browser.find_element_by_id('captcha1')code.send_keys(orcCode)# 执行登录browser.execute_script('personlogin();')# 关闭浏览器# browser.quit()

识别较复杂验证码算法

网上找的算法,先将图片转为灰度图,然后进行二值化处理(将图像上的像素点的灰度值设置为0或255。如灰度大于等于阈值的像素,用255表示。否则为0。),再去噪(8邻域降噪,判断8个邻域的黑色数量个数)。

ocrImage.py:

import pytesseractfrom PIL import Imagefrom collections import defaultdict# 获取图片中像素点数量最多的像素def get_threshold(image):  pixel_dict = defaultdict(int)  # 像素及该像素出现次数的字典  rows, cols = image.size  for i in range(rows):    for j in range(cols):      pixel = image.getpixel((i, j))      pixel_dict[pixel] += 1  count_max = max(pixel_dict.values()) # 获取像素出现出多的次数  pixel_dict_reverse = {v: k for k, v in pixel_dict.items()}  threshold = pixel_dict_reverse[count_max] # 获取出现次数最多的像素点  return threshold# 按照阈值进行二值化处理# threshold: 像素阈值def get_bin_table(threshold):  # 获取灰度转二值的映射table  table = []  for i in range(256):    rate = 0.1 # 在threshold的适当范围内进行处理    if threshold * (1 - rate) <= i <= threshold * (1 + rate):      table.append(1)    else:      table.append(0)  return table# 去掉二值化处理后的图片中的噪声点def cut_noise(image):  rows, cols = image.size # 图片的宽度和高度  change_pos = [] # 记录噪声点位置  # 遍历图片中的每个点,除掉边缘  for i in range(1, rows - 1):    for j in range(1, cols - 1):      # pixel_set用来记录该店附近的黑色像素的数量      pixel_set = []      # 取该点的邻域为以该点为中心的九宫格      for m in range(i - 1, i + 2):        for n in range(j - 1, j + 2):          if image.getpixel((m, n)) != 1: # 1为白色,0位黑色            pixel_set.append(image.getpixel((m, n)))      # 如果该位置的九宫内的黑色数量小于等于4,则判断为噪声      if len(pixel_set) <= 4:        change_pos.append((i, j))  # 对相应位置进行像素修改,将噪声处的像素置为1(白色)  for pos in change_pos:    image.putpixel(pos, 1)  return image # 返回修改后的图片# 识别图片中的数字加字母# 传入参数为图片路径,返回结果为:识别结果def ocr_img(img_path):  image = Image.open(img_path) # 打开图片文件  imgry = image.convert('L') # 转化为灰度图  # 获取图片中的出现次数最多的像素,即为该图片的背景  max_pixel = get_threshold(imgry)  # 将图片进行二值化处理  table = get_bin_table(threshold=max_pixel)  out = imgry.point(table, '1')  # 去掉图片中的噪声(孤立点)  out = cut_noise(out)  # 仅识别图片中的数字  # text = pytesseract.image_to_string(out, config='digits')  # 识别图片中的数字和字母  text = pytesseract.image_to_string(out)  # 去掉识别结果中的特殊字符  exclude_char_list = ' .:\\|\'\"?![],()~@#$%^&*_+-={};<>/&yen;'  text = ''.join([x for x in text if x not in exclude_char_list])  return text

如何使用python登录带弱图片验证码的网站

ocrImage.ocr_img('data/0021.png')

如何使用python登录带弱图片验证码的网站

其他

针对不同的图片验证码用的方法不尽相同,cv2模块也提供了很多图片的处理方法可以用于识别图片验证码。

如使用cv2的腐蚀和碰撞方法就可以对图片进行简单的处理。

干扰条件较多、识别难度大的则需要依靠机器学习来完成。

以上是“如何使用Python登录带弱图片验证码的网站”这篇文章的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注编程网Python频道!

--结束END--

本文标题: 如何使用python登录带弱图片验证码的网站

本文链接: https://lsjlt.com/news/268366.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • 如何使用python登录带弱图片验证码的网站
    小编给大家分享一下如何使用python登录带弱图片验证码的网站,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!图片验证码一般都通过加干扰线、粘连或扭曲等方式来增加强...
    99+
    2023-06-14
  • 用python登录带弱图片验证码的网站
    目录图片验证码登陆点击个人用户登录获取图片验证码识别并登陆识别较复杂验证码算法其他上一篇介绍了使用python模拟登陆网站,但是登陆的网站都是直接输入账号及密码进行登陆,现在很多网站...
    99+
    2024-04-02
  • 如何使用python批量登录带有验证码的网站
    小编给大家分享一下如何使用python批量登录带有验证码的网站,希望大家阅读完这篇文章之后都有所收获,下面让我们一起去探讨吧!python主要应用领域有哪些1、云计算,典型应用OpenStack。2、WEB前端开发,众多大型网站均为Pyth...
    99+
    2023-06-14
  • Python爬虫模拟登录带验证码网站
    爬取网站时经常会遇到需要登录的问题,这是就需要用到模拟登录的相关方法。python提供了强大的url库,想做到这个并不难。这里以登录学校教务系统为例,做一个简单的例子。 首先得明白cookie的作用,coo...
    99+
    2022-06-04
    爬虫 验证码 网站
  • Python实现破解网站登录密码(带token验证)
    目录前言关键代码解释完整代码运行结果补充前言 上一篇暴力破解文章:一个简单的Python暴力破解网站登录密码脚本 测试靶机为Pikachu漏洞练习平台暴力破解模块下的 “...
    99+
    2024-04-02
  • 教你怎么用python批量登录带有验证码的网站
    目录一、介绍二、准备三、实践3.1 下载驱动3.2 安装python依赖3.3 编写程序3.4 优化一、介绍 原理为使用selenium驱动chorme打开一个新的进程并打开数组中的...
    99+
    2024-04-02
  • Python之selenium,使用webdriver模拟登录网站(含验证码)
    一、前言 前段时间做了一个小项目,其中有一段需要自动获取网站后台的数据,但是这个网站没有任何提供给开发者的API,所以只能靠自己去探索。 起初想着用发送请求的方式去模拟登陆,获取cookies,从而再获取网站后台数据,但是因为自己太菜了一些...
    99+
    2023-09-29
    python selenium 测试工程师 软件测试 性能测试 自动化测试 测试工具
  • 怎么使用java搞定网站登录验证码
    这篇文章主要讲解了“怎么使用java搞定网站登录验证码”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“怎么使用java搞定网站登录验证码”吧!验证码生成本效果是利用easy-captcha工具...
    99+
    2023-07-05
  • vue实现登录时的图片验证码
    本文实例为大家分享了vue实现登录时的图片验证码的具体代码,供大家参考,具体内容如下 效果图 一、新建vue组件components/identify/identify.vue ...
    99+
    2024-04-02
  • python 模拟网站登录——滑块验证码的识别
    普通滑动验证 以http://admin.emaotai.cn/login.aspx为例这类验证码只需要我们将滑块拖动指定位置,处理起来比较简单。拖动之前需要先将滚动条滚动到指定元...
    99+
    2024-04-02
  • Springboot+SpringSecurity实现图片验证码登录的示例
    这个问题,网上找了好多,结果代码都不全,找了好多,要不是就自动注入的类注入不了,编译报错,要不异常捕获不了浪费好多时间,就觉得,框架不熟就不能随便用,全是坑,气死我了,最后改了两天....
    99+
    2024-04-02
  • 5分钟教你使用java搞定网站登录验证码
    目录正文验证码生成验证码格式后端逻辑的实现前端逻辑的实现验证码验证后端代码前端代码效果结束语正文 我们其实很经常看到,登录一些网站其实是需要验证码的。使用验证码是现在很多网站通行的...
    99+
    2023-05-14
    java 网站登录验证码 java 验证码
  • python爬虫模拟登录之图片验证码实现详解
    我们在用爬虫对门户网站进行模拟登录是总会有输入图片验证码的,例如这种 那我们怎么解决这个问题实现全自动的模拟登录呢?只要思想不滑坡,办法总比困难多。我这里使用的是百度智能云里面的文...
    99+
    2024-04-02
  • vue如何实现登录时图形验证码
    这篇文章主要介绍vue如何实现登录时图形验证码,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!具体内容如下效果图:点击图案可以切换字符1.新建 Identify.vue 组件<template> ...
    99+
    2023-06-29
  • Django中使用pillow实现登录验证码功能(带刷新验证码功能)
    首先在项目里建立common目录,编写验证码的函数 verification_code.py import random from PIL import Image, Imag...
    99+
    2024-04-02
  • 使用java如何生成一个验证码图片
    本文章向大家介绍使用java如何生成一个验证码图片的基本知识点总结和需要注意事项,具有一定的参考价值,需要的朋友可以参考一下。Java的特点有哪些Java的特点有哪些1.Java语言作为静态面向对象编程语言的代表,实现了面向对象理论,允许程...
    99+
    2023-06-06
  • 如何使用AJAX验证用户登录
    这篇文章将为大家详细讲解有关如何使用AJAX验证用户登录,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。我们来分一下步骤吧:1.HTML代码,页面先写出来;2.正则表达式验...
    99+
    2024-04-02
  • Laravel8 使用图形验证码做登录功能的实现
    一、 安装扩展包 composer require gregwar/captcha 二、定义路由 //路由分组 Route::group(['prefix'=>'admi...
    99+
    2024-04-02
  • Python使用PIL库实现验证码图片的方法
    本文实例讲述了Python使用PIL库实现验证码图片的方法。分享给大家供大家参考,具体如下: 现在的网页中,为了防止机器人提交表单,图片验证码是很常见的应对手段之一。这里就不详细介绍了,相信大家都遇到过。 ...
    99+
    2022-06-04
    验证码 方法 图片
  • node+vue前后端分离实现登录时使用图片验证码功能
    目录后端代码前端代码获取验证码方法登录验证方法记录一下前端使用验证码登录的过程后端用的是node.js,关键模块是svg-captcha前端使用的是vue2最后的登录界面如下: 后...
    99+
    2022-11-13
     vue图片验证码登录 node前后端分离验证码登录
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作