"```python

import base64

import random

from PIL import Image

from PIL import ImageDraw # 画笔对象

from PIL import ImageFont # 字体对象

from io import BytesIO # 可将数据写到内存中

class AuthCode(object):

def __init__(self, digits=5, is_letter=False, image_size=(245, 40), font_path='kumo.ttf', font_size=36,
is_interfering_line=True,
interfering_line_count=1,
is_interfering_point=True,
interfering_point_count=10,
is_save_disk=False,
save_disk_path=None, # 保存到磁盘的路径,如果保存至磁盘,则必须save_disk_path
is_save_memory=True):
"""
内部功能全部通过传参调用
:param digits: 验证码长度
:param is_letter: 验证码是否包含字母
:param image_size: 图片大小 ("宽度", "高度")
:param font_path: 字体文件路径
:param font_size: 生成的字体大小
:param is_interfering_line: 是否给图片加干扰线
:param interfering_line_count: 干扰线数量
:param is_interfering_point: 是否给图片加干扰点
:param interfering_point_count: 干扰点数量
:param is_save_disk: 默认保存到磁盘
:param save_disk_path: 保存到磁盘的路径,如果保存至磁盘,则必须传入一个有效路径
:param is_save_memory: 是否保存到内存(以便传输)
"""
self.digits = digits
self.is_letter = is_letter
self.image_size = image_size
self.font_path = font_path
self.font_size = font_size
self.is_interfering_line = is_interfering_line
self.interfering_line_count = interfering_line_count
self.is_interfering_point = is_interfering_point
self.interfering_point_count = interfering_point_count
self.is_save_disk = is_save_disk
self.save_disk_path = save_disk_path
self.is_save_memory = is_save_memory self.__code = self.__code_s() if self.is_letter else self.__code() # 获取验证码
img_obj, draw_obj = self.__image()
# 开始在图片上写验证码
[draw_obj.text((i * 56, 0), self.__code[i], self.__rgb_color(), self.__font()) for i in range(self.digits)]
# 是否增加干扰属性
self.is_interfering_line and self.__add_interfering_line(draw_obj)
self.is_interfering_point and self.__add_interfering_point(draw_obj)
# 将完工的图片保存
self.is_save_disk and self.__save_to_disk(img_obj)
self.is_save_memory and self.__save_to_memory(img_obj) def get_code(self):
"""用于获取生成的验证码内容"""
return self.__code def get_memory_img_data(self):
"""用于获取保存在内存中的图片"""
return base64.b64encode(self.__img_data) def __save_to_disk(self, img_obj):
"""将图片保存到磁盘"""
with open(self.save_disk_path, 'wb') as f:
img_obj.save(f, format='png') def __save_to_memory(self, img_obj):
"""保存至内存"""
f = BytesIO()
img_obj.save(f, format='png')
self.__img_data = f.getvalue() def __code(self):
"""数字验证码"""
return [str(random.randint(0, 9)) for i in range(self.digits)] def __code_s(self):
"""数字字母验证码"""
code = ''
for i in range(self.digits):
big_letter = chr(random.randint(65, 90)) # 大写字母
small_letter = chr(random.randint(97, 122)) # 小写字母
num = str(random.randint(0, 9))
code += random.choice([big_letter, small_letter, num])
return code def __rgb_color(self):
"""随机返回RBG颜色类型的三个值"""
return random.randint(0, 255), random.randint(0, 255), random.randint(0, 255) def __image(self):
"""返回一个图片对象和这个图片对象的画笔对象"""
img_obj = Image.new('RGB', self.image_size, self.__rgb_color()) # 生成一个图片对象
# img_obj = Image.new("颜色类型", (图片宽度, 图片高度), (RGB的三个值))
draw_obj = ImageDraw.Draw(img_obj) # 在该图片对象上生成一个画笔对象
return img_obj, draw_obj def __font(self):
"""返回一个字体对象, 需先下载字体"""
# return ImageFont.truetype("字体路径", "字体大小")
return ImageFont.truetype(self.font_path, self.font_size) def __add_interfering_line(self, draw_obj):
"""加干扰线"""
width, height = self.image_size # 图片高宽(防止越界)
for i in range(self.interfering_line_count):
x1 = random.randint(0, width)
x2 = random.randint(0, width)
y1 = random.randint(0, height)
y2 = random.randint(0, height)
draw_obj.line((x1, y1, x2, y2), fill=self.__rgb_color()) def __add_interfering_point(self, draw_obj):
"""加干扰点"""
width, height = self.image_size # 图片高宽(防止越界)
for i in range(self.interfering_point_count):
draw_obj.point([random.randint(0, width), random.randint(0, height)], fill=self.__rgb_color())
x = random.randint(0, width)
y = random.randint(0, height)
draw_obj.arc((x, y, x + 4, y + 4), 0, 90, fill=self.__rgb_color())

if name == 'main':

# 生成验证码

obj = AuthCode(font_path='字体文件路径')

# 获取验证码内容
obj.get_code() # 获取保存在内存中的验证码数据
obj.get_memory_img_data()
[Python下的PIL模块支持的字体文件下载](https://download.csdn.net/my/uploads)
下载后,指定文件路径即可.
"

【Python实现图片验证码】的更多相关文章

  1. python随机图片验证码的生成

    Python生成随机验证码,需要使用PIL模块. 安装: 1 pip3 install pillow 基本使用 1. 创建图片 1 2 3 4 5 6 7 8 9 from PIL import Im ...

  2. python实现图片验证码

    1 验证基础知识1.1 Python生成随机验证码,需要使用PIL模块. # 安装 pip3 install pillow 1.2 创建图片 from PIL import Image img = I ...

  3. 字符识别Python实现 图片验证码识别

    字符型图片验证码识别完整过程及Python实现 1   摘要 验证码是目前互联网上非常常见也是非常重要的一个事物,充当着很多系统的 防火墙 功能,但是随时OCR技术的发展,验证码暴露出来的安全问题也越 ...

  4. python 识别图片验证码报IOError

    说一下困扰了我一周的问题:识别图片验证码 本来我按照安装步骤(http://www.cnblogs.com/yeayee/p/4955506.html?utm_source=tuicool&u ...

  5. python添加图片验证码

    1.创建验证码模块 #!/usr/bin/env python # -*- coding:utf-8 -*- import random from PIL import Image, ImageDra ...

  6. python爬虫20 | 小帅b教你如何使用python识别图片验证码

    当你在爬取某些网站的时候 对于你的一些频繁请求 对方会阻碍你 常见的方式就是使用验证码 验证码的主要功能 就是区分你是人还是鬼(机器人) 人 想法设法的搞一些手段来对付技术 而 技术又能对付人们的想法 ...

  7. Python实现图片验证码识别

    转载地址:https://blog.csdn.net/EB_NUM/article/details/77060009 具体想要实现上面的代码需要安装两个包和一个引擎 在安装之前需要先安装好Python ...

  8. 字符型图片验证码识别完整过程及Python实现

    字符型图片验证码识别完整过程及Python实现 1   摘要 验证码是目前互联网上非常常见也是非常重要的一个事物,充当着很多系统的 防火墙 功能,但是随时OCR技术的发展,验证码暴露出来的安全问题也越 ...

  9. 【python】带图片验证码的登录自动化实战

    近期在跟进新项目的时候,整体的业务线非常之长,会一直重复登录退出不同账号的这个流程,所以想从登录开始实现部分的自动化.因为是B/S的架构,所以采用的是selenium的框架来实现.大致实现步骤如下: ...

随机推荐

  1. docker镜像相关的常用操作

    1.保存镜像 #docker save 镜像名称 -o 保存的完整地址和文件名 docker save zhoushiya/zhiboyuan -o d:/zhiboyuan.tar 2.载入镜像 # ...

  2. arm-linux下qt + opencv开发环境的搭建(Altera DE1 Soc)

    arm-linux-gnueabihf-gcc下载 qt下载 arm-linux下qt + opencv开发环境的搭建(Altera DE1 Soc) Ubuntu 16.04 安装QT arm嵌入式 ...

  3. SpringBoot--SSM框架整合

    方式一 1 建立一个Spring Starter 2.在available中找到要用的包,配置mybatis 3.建立file,application.yml 文件 spring: datasourc ...

  4. python之路递归、冒泡算法、装饰器

    map使用 完整用户名登录,注册 冒泡排序 递归 def func(arg1,arg2): if arg1 == 0: print arg1, arg2 arg3 = arg1 + arg2 prin ...

  5. php设计模式之策略模式实例代码

    html <html> <head> <meta charset="UTF-8"> <title>简单计算器</title&g ...

  6. shell编程基础知识

    什么是shell shell是一个命令解释器,它在操作系统的最外层,负责直接与用户对话,把用户的输入解释给操作系统,并处理各种各样的操作系统的输出结果,输出屏幕返回给用户 shell对话方式 交互的方 ...

  7. 【Python】random库

    种子相同,随机数相同

  8. js 简单粗暴深拷贝

    var obj = {} var newObj = JSON.parse(JSON.stringify(obj))

  9. 【新特性速递】F.doPostBack的说明文档

    FineUIPro/Mvc/Core的下个版本(v6.1.0),我们对客户端JS函数 F.doPostBack 进行了增强,并增加说明文档. 如果你还没有查阅过FineUI的客户端文档,可以收藏下这个 ...

  10. python3爬取高清壁纸(1)

    这次爬取的目标是:美桌网首页 > 桌面壁纸 > 卡通动漫 类别下的壁纸. 我们先随机选取一个专辑来爬(http://www.win4000.com/wallpaper_detail_545 ...