利用Python生成随机验证码详解

作者:程序猿李巡天 时间:2021-10-04 19:55:50 

最近感觉被大数据定义成机器人了,随便看个网页都跳验证码。

利用Python生成随机验证码详解

怎么用python绕验证码是个令人头秃的事情,

我投降!那么今天手把手教大家如何写验证码,去为难别人,让他们头秃。

说错了,其实就是教大家如何通过python代码去生成验证码~~

1.先搞环境

1.我们需要你电脑有python3.4以上的版本

2.pip安装PIL包

pip install pillow

3.默念一遍"人生苦短,我用python",之后打开IDLE开始码代码!

2.开始码代码

1. 确定画布大小和背景色

# 导入相关的绘画模块
from PIL import Image, ImageDraw, ImageFont

# 设置背景色
bg_color = (100, 100, 255)

#设置画布长宽(像素)
width = 400
height = 100

# 通过设置生成新的画布
im = Image.new('RGB',(width,height),bg_color)
# 展示画布
im.show()

在这 bg_color 背景色的设置是用 RGB 颜色标准去设置的,如果你不喜欢这个背景色可以自己调一下。

利用Python生成随机验证码详解

“常见的RGB颜色

利用Python生成随机验证码详解

运行代码后:

利用Python生成随机验证码详解

2. 往背景布上画字符

先上代码

from PIL import Image, ImageDraw, ImageFont

# 省略第一步的代码

# 创建画笔对象
draw = ImageDraw.Draw(im)
# 验证码文本
string = 'MSBC'
# 构造字体对象
font = ImageFont.truetype('./ziti.ttf', 90)
# font = ImageFont.load_default().font
# 构造字体颜色
fontcolor = (255, 100, 100)
# 绘制4个字
draw.text((10, 2), string[0], font=font, fill=fontcolor)
draw.text((110, 2), string[1], font=font, fill=fontcolor)
draw.text((210, 2), string[2], font=font, fill=fontcolor)
draw.text((310, 2), string[3], font=font, fill=fontcolor)

#释放画笔
del draw
#展示图片
im.show()

代码分析:

draw = ImageDraw.Draw(im)

在im画布上实例化一只笔。

font = ImageFont.truetype('./ziti.ttf', 90)
# font = ImageFont.load_default().font

第一个参数是设置字体,我这有下载一个ttf的字体文件所以可以用它,如果没有指定的字体文件可以使用默认的 # font = ImageFont.load_default().font;

第二个参数是绘制字体的大小,因为我们画布是400x100的 所以我们为了美观就把字体设成90x90的尺寸。

# 构造字体颜色
fontcolor = (255, 100, 100)

字体文本的颜色,参照第一步画布的 RGB 设置。

# 绘制4个字
draw.text((10, 2), string[0], font=font, fill=fontcolor)
draw.text((110, 2), string[1], font=font, fill=fontcolor)
draw.text((210, 2), string[2], font=font, fill=fontcolor)
draw.text((310, 2), string[3], font=font, fill=fontcolor)

这里 draw.text 函数,顾名思义就是开始拿画起画笔开始写字,

第一个参数 写字的坐标;

第二个参数 要写的字;

第三个参数 字的颜色(上面构造过了,你也可以设成一字一色)。

代码跑一下看成果:

利用Python生成随机验证码详解

效果还行,就是总觉得少了点什么?

3. 加干扰

既然是验证码,肯定要稍微难识别,上面那个那么傻白甜的验证码是怎么回事??

这一步我们需要导入 random 模块,因为干扰是不规则随机生成的。

import random
from PIL import Image, ImageDraw, ImageFont

# 省略第一步代码

# 省略第二步代码

#使用point函数绘制噪点
for i in range(0, 100):
    xy = (random.randrange(0, width), random.randrange(0, height))
    fill = (random.randrange(0, 255), 255, random.randrange(0, 255))
    draw.point(xy, fill=fill)
    
#释放画笔
del draw   
im.show()

代码分析:

import random

别忘了导入 random 模块

for i in range(0, 100):
   xy = (random.randrange(0, width), random.randrange(0, height))
   fill = (255, 255, 255)
   draw.point(xy, fill=fill)

一个循环100次的 for 循环,

xy 变量是画干扰点的坐标值

fill 变量是噪点的颜色,还是 RGB 标准的

draw.point 画点的动作

“这个for循环的次数越多,画布上噪点也会相应增多。

跑一下代码看看噪点的效果如何:

利用Python生成随机验证码详解

感觉还是有点傻白甜,我们来循环1000次的试试:

利用Python生成随机验证码详解

10000次!

利用Python生成随机验证码详解

够了。

4. 加入更多的干扰

这一步我将各个参数结合 random 模块,使我们的验证码更难辨别!

import random
from PIL import Image, ImageDraw, ImageFont

bg_color = (random.randrange(20, 120), random.randrange(20, 120), random.randrange(150, 255))
width = 400
height = 100

im = Image.new('RGB',(width,height),bg_color)
# 创建画笔对象
draw = ImageDraw.Draw(im)

# 构造字体对象
font = ImageFont.truetype('./ziti.ttf', 100)
# font = ImageFont.load_default().font
# 构造字体颜色
fontcolor = (random.randrange(0, 255), random.randrange(0, 255), random.randrange(0, 255))
# 绘制4个字
string = 'MSBC'
draw.text((random.randint(10, 30), (random.randint(0, 10))), string[0], font=font, fill=fontcolor)
draw.text((random.randint(90, 130), (random.randint(0, 10))), string[1], font=font, fill=fontcolor)
draw.text((random.randint(180, 230), (random.randint(0, 10))), string[2], font=font, fill=fontcolor)
draw.text((random.randint(270, 330), (random.randint(0, 10))), string[3], font=font, fill=fontcolor)

#调用画笔的point()函数绘制噪点
for i in range(0, 10000):
    xy = (random.randrange(0, width), random.randrange(0, height))
    fill = (random.randrange(0, 255), random.randrange(0, 255), random.randrange(0, 255))
    draw.point(xy, fill=fill)

#释放画笔
del draw
im.show()

我把字体颜色,噪点颜色,文本位置都结合了random模块,效果图如下:

利用Python生成随机验证码详解

5. 验证码 + 随机字符

这一步,我们需要把上面的代码封装到函数中,大致把上面代码重构成:

# 使用for循环生成文本字符

# 生成验证码图片的函数,参数就是上面生成的文本

# 调用生成验证码图片函数

重构后:

import random
from PIL import Image, ImageDraw, ImageFont

string = ''
#随机选取4个值作为验证码
rand_str = 'ABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789'
for i in range(0, 4):
    string += rand_str[random.randrange(0, len(rand_str))]

def gen_verify_img(text):
    bg_color = (random.randrange(20, 120), random.randrange(20, 120), random.randrange(150, 255))
    width = 400
    height = 100

    im = Image.new('RGB',(width,height),bg_color)
    # 创建画笔对象
    draw = ImageDraw.Draw(im)

    # 构造字体对象
    font = ImageFont.truetype('./ziti.ttf', 100)
    # font = ImageFont.load_default().font
    # 构造字体颜色
    fontcolor = (random.randrange(0, 255), random.randrange(0, 255), random.randrange(0, 255))
    # 绘制4个字
    draw.text((random.randint(10, 30), (random.randint(0, 10))), string[0], font=font, fill=fontcolor)
    draw.text((random.randint(90, 130), (random.randint(0, 10))), string[1], font=font, fill=fontcolor)
    draw.text((random.randint(180, 230), (random.randint(0, 10))), string[2], font=font, fill=fontcolor)
    draw.text((random.randint(270, 330), (random.randint(0, 10))), string[3], font=font, fill=fontcolor)

    #调用画笔的point()函数绘制噪点
    for i in range(0, 10000):
        xy = (random.randrange(0, width), random.randrange(0, height))
        fill = (random.randrange(0, 255), random.randrange(0, 255), random.randrange(0, 255))
        draw.point(xy, fill=fill)

    #释放画笔
    del draw
    im.show()

# 调用函数
gen_verify_img(string)

把原先代码中的 string 变量提到了函数外,把它变成函数需要传入的参数,

再用 for 循环,随机选出4个字符。

string = ''
#随机选取4个值作为验证码
rand_str = 'ABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789'
for i in range(0, 4):
   string += rand_str[random.randrange(0, len(rand_str))]

代码再跑一下:

利用Python生成随机验证码详解

上面的验证码是 DZNO 还是 DZN0 ?

6. 验证码保存本地(选)

在web开发的登录操作,和训练验证码识别的神经运算中,都需要大量的验证码图片。

所以需要把大量的验证码图片文件,我们将批量验证码保存到本地。

利用Python生成随机验证码详解

完整代码:

import random
from PIL import Image, ImageDraw, ImageFont

def gen_verify_img(text):
    bg_color = (random.randrange(20, 120), random.randrange(20, 120), random.randrange(150, 255))
    width = 400
    height = 100

    im = Image.new('RGB',(width,height),bg_color)
    # 创建画笔对象
    draw = ImageDraw.Draw(im)

    # 构造字体对象
    font = ImageFont.truetype('./ziti.ttf', 100)
    # font = ImageFont.load_default().font
    # 构造字体颜色
    fontcolor = (random.randrange(0, 255), random.randrange(0, 255), random.randrange(0, 255))
    # 绘制4个字
    draw.text((random.randint(10, 30), (random.randint(0, 10))), string[0], font=font, fill=fontcolor)
    draw.text((random.randint(90, 130), (random.randint(0, 10))), string[1], font=font, fill=fontcolor)
    draw.text((random.randint(180, 230), (random.randint(0, 10))), string[2], font=font, fill=fontcolor)
    draw.text((random.randint(270, 330), (random.randint(0, 10))), string[3], font=font, fill=fontcolor)

    #调用画笔的point()函数绘制噪点
    for i in range(0, 10000):
        xy = (random.randrange(0, width), random.randrange(0, height))
        fill = (random.randrange(0, 255), random.randrange(0, 255), random.randrange(0, 255))
        draw.point(xy, fill=fill)

    #释放画笔
    del draw
    # im.show()
    im.save(f'./{text}.png','png')

for i in range(100):
    string = ''
    #随机选取4个值作为验证码
    rand_str = 'ABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789'
    for i in range(0, 4):
        string += rand_str[random.randrange(0, len(rand_str))]
    gen_verify_img(string)
    print(f'{string} 验证码生成成功!!')

最后再跑一下:

利用Python生成随机验证码详解

部分验证码展示:

利用Python生成随机验证码详解

注:如果再将本文中的代码进行变形或改写,可能会得到更五花八门的验证码,怎么发挥就看屏幕钱你的了。

来源:https://blog.csdn.net/m0_59235945/article/details/122667494

标签:Python,随机,验证码
0
投稿

猜你喜欢

  • Python抓新型冠状病毒肺炎疫情数据并绘制全国疫情分布的代码实例

    2022-10-11 23:14:40
  • python 中的命名空间,你真的了解吗?

    2023-12-23 20:19:58
  • MySQL数据库中对前端和后台进行系统优化

    2009-01-04 13:39:00
  • PHP+MYSQL不恶补十句话

    2009-12-02 10:09:00
  • pandas DataFrame运算的实现

    2021-06-02 21:08:22
  • 对IPython交互模式下的退出方法详解

    2021-08-04 10:03:11
  • 经验之谈:MySQL与ASP.NET配合更强大

    2008-12-23 15:26:00
  • 使用Python下的XSLT API进行web开发的简单教程

    2022-07-24 22:07:14
  • Python爬虫爬取杭州24时温度并展示操作示例

    2022-01-04 14:43:33
  • Python中类型检查的详细介绍

    2022-08-18 16:51:47
  • Python reques接口测试框架实现代码

    2023-10-07 12:47:08
  • javascript闭包的秘密

    2008-09-28 20:39:00
  • PHP addslashes()函数讲解

    2023-06-04 04:28:24
  • 注册和填表中常见的中英文对照

    2008-07-26 12:12:00
  • ASP技巧:Script块不能放在另一个Script 块内

    2009-08-19 17:17:00
  • ASP检测服务器相关的一些代码

    2008-01-25 19:20:00
  • 自适应网页设计(Responsive Web Design)

    2012-05-02 10:49:07
  • 在Django model中设置多个字段联合唯一约束的实例

    2021-02-09 22:04:59
  • 详谈python3 numpy-loadtxt的编码问题

    2021-08-28 06:42:09
  • Oracle临时表空间删除和重建实现过程

    2023-07-18 09:26:04
  • asp之家 网络编程 m.aspxhome.com