生成随机图片验证码
随着互联网的不断发展,安全性问题日益突出。为了保障用户账号的安全性,很多网站都引入了验证码机制。验证码是一种区分用户是计算机还是人的公共全自动程序,可以有效防止恶意攻击和自动化脚本的滥用。本文将介绍如何使用Python生成随机图片验证码,提高网站的安全性。
效果图
一、准备工作
在生成随机图片验证码之前,我们需要准备一些必要的库和工具。首先,我们需要安装Python环境,然后使用pip安装以下库:
- PIL(Python Imaging Library):用于图像处理和操作。
- random:用于生成随机数。
- 下载字体文件:字体文件
可以通过以下命令安装这些库:
pip install pillow
二 功能介绍
1. 生成随机验证码
import random
import string # 生成指定长度的随机验证码
all_chars = string.ascii_letters + string.digits # 包含大小写字母和数字
random_code = ''.join(random.choice(all_chars) for _ in range(4))
print(random_code)
通过string生成随机大小字母数组长度为4的字符串
2. 创建图片
from PIL import Image
img = Image.new(mode='RGB', size=(120, 30), color=(255, 255, 255))with open('code.png','wb') as f:img.save(f,format='png')
通过pillow模块可以创建图片, 如图可以指定图片的大小和颜色。
3. 创建画笔
from PIL import Image, ImageDraw# 创建一个新的白色图像,大小为200x200像素
image = Image.new('RGB', (200, 200), color=(255, 255, 255))# 创建一个可以在给定图像上绘图的对象
draw = ImageDraw.Draw(image)# 画线
# 参数分别为:起始点的x坐标,起始点的y坐标,结束点的x坐标,结束点的y坐标,线条颜色,线条宽度
draw.line((0, 0, 200, 200), fill=(0, 0, 0), width=5) # 从(0, 0)到(200, 200)画一条黑色线条,宽度为5 # 画点
# 参数分别为:点的x坐标,点的y坐标,点的颜色
draw.point((100, 100), fill=(255, 0, 0)) # 在(100, 100)处画一个红色点 # 画圆
# 参数分别为:圆心的x坐标,圆心的y坐标,半径,填充颜色(可选),线条颜色(可选),线条宽度(可选)
draw.ellipse((50, 50, 150, 150), fill=(0, 255, 0), outline=(0, 0, 255)) # 画一个绿色的圆,边缘为红色,位置由矩形的左上角和右下角坐标定义 # 画矩形
# 参数分别为:矩形左上角的x坐标,矩形左上角的y坐标,矩形右下角的x坐标,矩形右下角的y坐标,填充颜色(可选),线条颜色(可选),线条宽度(可选)
draw.rectangle((10, 10, 190, 190), fill=None, outline=(0, 0, 255), width=3) # 画一个红色的矩形框,位置由左上角和右下角坐标定义 draw.text([100,100],'python',"red")
# 显示图像
image.show()
创建画笔之后,就能在上一个步骤中创建的图片中根据自己的需要将生成的验证码画在图片上
4. 添加文字资源
font = ImageFont.truetype("kumo.ttf", 28)
使用pillow中的默认字体是正常的字体,但是这种字体容易被爬虫给破解,需要更换字体
5. 添加干扰
# 写干扰点
for i in range(20):draw.point([random.randint(0, self.width), random.randint(0, self.height)], fill=self.random_color())# 写干扰圆圈
for i in range(20):draw.point([random.randint(0, self.width), random.randint(0, self.height)], fill=self.random_color())x = random.randint(0, self.width)y = random.randint(0, self.height)draw.arc((x, y, x + 4, y + 4), 0, 90, fill=self.random_color())# 画干扰线
for i in range(5):x1 = random.randint(0, self.width)y1 = random.randint(0, self.height)x2 = random.randint(0, self.width)y2 = random.randint(0, self.height)draw.line((x1, y1, x2, y2), fill=self.random_color())
# 应用模糊滤镜,增加干扰效果
self.img = self.img.filter(ImageFilter.EDGE_ENHANCE_MORE)
更换了字体后安全性也不是很高,需要在图片上增加一些干扰的元素,防止爬虫失败到图片中的验证码。
未增加干扰和增加干扰的对比
三、使用示例
现在我们可以将上述函数结合起来,生成一个随机图片验证码,并将其保存为文件或直接在网页上显示。
import random
import string
from PIL import Image, ImageDraw, ImageFilter, ImageFontclass ImageCode:def __init__(self, width=120, height=30, char_length=5, font_file='kumo.ttf', font_size=28):self.width = widthself.height = heightself.char_code = Noneself.char_length = char_lengthself.font_file = font_fileself.font_size = font_sizeself.img = Image.new(mode='RGB', size=(self.width, self.height), color=(255, 255, 255))def random_code(self):"""生成指定长度的随机验证码"""all_chars = string.ascii_letters + string.digits # 包含大小写字母和数字random_code = ''.join(random.choice(all_chars) for _ in range(self.char_length))return random_code@staticmethoddef random_color():"""生成随机颜色"""return (random.randint(0, 255), random.randint(10, 255), random.randint(64, 255))def draw_code(self, draw):"""画随机码"""font = ImageFont.truetype(self.font_file, self.font_size)for i in range(self.char_length):char = self.char_code[i]h = random.randint(0, 4)draw.text([i * self.width / self.char_length, h], char, font=font, fill=self.random_color())def add_interfere(self, draw):"""添加干扰"""# 写干扰点for i in range(20):draw.point([random.randint(0, self.width), random.randint(0, self.height)], fill=self.random_color())# 写干扰圆圈for i in range(20):draw.point([random.randint(0, self.width), random.randint(0, self.height)], fill=self.random_color())x = random.randint(0, self.width)y = random.randint(0, self.height)draw.arc((x, y, x + 4, y + 4), 0, 90, fill=self.random_color())# 画干扰线for i in range(5):x1 = random.randint(0, self.width)y1 = random.randint(0, self.height)x2 = random.randint(0, self.width)y2 = random.randint(0, self.height)draw.line((x1, y1, x2, y2), fill=self.random_color())# 应用模糊滤镜,增加干扰效果self.img = self.img.filter(ImageFilter.EDGE_ENHANCE_MORE)def save_image(self, image_file):f = open(image_file, "wb")self.img.save(f, format="png")def get_image_code(self):self.char_code = self.random_code()draw = ImageDraw.Draw(self.img, mode='RGB')self.draw_code(draw)self.add_interfere(draw)image_file = "image_code.png"self.save_image(image_file)return image_file, self.char_codeif __name__ == '__main__':img_code = ImageCode()image_file, image_code = img_code.get_image_code()print(image_file, image_code)
运行上述代码后,将生成一个名为image_code.png
的图片文件,其中包含了随机生成的验证码。你可以将此图片嵌入到你的网站中,要求用户输入验证码以进行验证。
四、总结
本文介绍了如何使用Python生成随机图片验证码的过程。通过生成随机字符串和绘制干扰线,我们可以创建一个安全可靠的验证码系统,提高网站的安全性。你可以根据自己的需求进行进一步的扩展和优化,例如添加更多的干扰元素、调整字体和颜色等。希望本文对你有所帮助!
相关文章:

生成随机图片验证码
随着互联网的不断发展,安全性问题日益突出。为了保障用户账号的安全性,很多网站都引入了验证码机制。验证码是一种区分用户是计算机还是人的公共全自动程序,可以有效防止恶意攻击和自动化脚本的滥用。本文将介绍如何使用Python生成随机图片验…...

【0280】《数据库系统概论》阅读总结(附xmind思维导图)
0. 阅读进展 选择性地读取了《数据库系统概论》一书中的第13、14章节,并对这两章节中较为重点的内容作了总结和归纳;然后以xmind导图形式给出。 1. xmind思维导图 Xmind附件:...

数据结构(二)----线性表(顺序表,链表)
目录 1.线性表的概念 2.线性表的基本操作 3.存储线性表的方式 (1)顺序表 •顺序表的概念 •顺序表的实现 静态分配: 动态分配: 顺序表的插入: 顺序表的删除: 顺序表的按位查找: 顺序…...
为什么你选择成为一名程序员?
文章目录 ✍选择成为程序员:兴趣与职业发展的交汇💎1 兴趣的驱动💎2 职业发展的需求💎3 结语 ✍选择成为程序员:兴趣与职业发展的交汇 在当今数字化时代,程序员已经成为一个备受瞩目的职业。无论是因为对技…...
【Android】系统启动流程分析 —— SystemServer 处理过程
本文基于 Android 14.0.0_r2 的系统启动流程分析。 SystemServer 进程主要用于创建系统服务,我们熟知的 AMS、WMS 和 PMS 都是由它来创建的,因此掌握 SystemServer 进程是如何启动的,它在启动时做了哪些工作是十分必要的。 一、源码解析 Zyg…...

Web前端—属性描述符
属性描述符 假设有一个对象obj var obj {a:1 }观察这个对象,我们如何来描述属性a: 值为1可以重写可以遍历 我们可以通过Object.getOwnPropertyDescriptor得到它的属性描述符 var desc Object.getOwnPropertyDescriptor(obj, a); console.log(desc);我…...

SpringBoot及其特性
0.前言 Spring 框架提供了很多现成的功能。那么什么是 Spring Boot?使用 Spring 框架,我们可以避免编写基础框架并快速开发应用程序。为了让 Spring 框架提供基础框架,我们需要向 Spring 框架描述有关我们的应用程序及其组件的信息。 不只是…...

「JavaEE」初识进程
初识进程 🍉进程🍌操作系统的进程管理 🍉PCB 重要属性🍌进程的身份标识🍌内存指针🍌文件描述符表🍌进程的状态🍌优先级🍌记账信息🍌上下文 🍉内存…...

计算机视觉——图像特征提取D2D先描述后检测特征提取算法原理
概述 局部特征提取是计算机视觉中的一个重要任务,它旨在从图像中提取出能够代表图像局部结构和外观信息的特征。这些特征通常用于图像匹配、物体识别、三维重建、跟踪和许多其他应用。传统方法,如尺度不变特征变换(SIFT)…...
The “from“ argument must be of type string. Received undefined——vue报错记录
今天在用机器人打包测试环境时,一直报错: The "from" argument must be of type string. Received undefined 啥意思呐? 百度也没有找到对应的问题所在。 下面写一下我的解决方法: vue.config.js 在vue.config.js中…...

汽车4S行业的信息化特点与BI建设挑战
汽车行业也是一个非常大的行业,上下游非常广,像主机厂,上游的零配件,下游的汽车流通,汽车流通之后的汽车后市场,整个链条比较长。今天主要讲的是汽车流通,汽车4S集团。一个汽车4S集团下面授权代…...
JSX 和 HTML 之间的区别
JSX和 HTML 都是用于创建和构建网页的标记语言,但它们有一些关键的区别。 1. JSX 是 JavaScript 的语法扩展,而 HTML 是一种标记语言。 2. JSX 允许您在语法中包含表达式和函数,而 HTML 只允许静态文本。 3. JSX 通常用于 React 应用程序&…...

AI日报:GPT-4-Turbo正式版自带读图能力;Gemini1.5Pro开放API;SD3将于4月中旬发布;抖音宫崎骏AI特效爆火
欢迎来到【AI日报】栏目!这里是你每天探索人工智能世界的指南,每天我们为你呈现AI领域的热点内容,聚焦开发者,助你洞悉技术趋势、了解创新AI产品应用。 新鲜AI产品点击了解:AIbase - 智能匹配最适合您的AI产品和网站 ὏…...
IDEA 宝贝插件
1. Codota— 代码智能提示 Codota还包含一个网站:https://www.codota.com/code 2.Alibaba Java Code Guidelines— 阿里巴巴 Java 代码规范 3. SequenceDiagram —— 调用链路自动生成时序图 4. google-java-format —— 代码自动格式化...

[C语言][数据结构][链表] 单链表的从零实现!
目录 零.必备知识 1.一级指针 && 二级指针 2. 节点的成员列表 a.数据 b.指向下一个节点的指针. 3. 动态内存空间的开辟 (malloc-calloc-realloc) 一.单链表的实现与销毁 1.1 节点的定义 1.2 单链表的尾插 1.3 单链表的头插 1.4 单链表的尾删 1.5 单链表的头删 1…...
oracle rac打补丁后sqlplus / as sysdba ora-12537
sqlplus / as sysdba 报错: ORA-12537: TNS:connection closed 检查用户属组: [rootrac1 ~]# id oracle uid1102(oracle) gid1101(oinstall) groups1101(oinstall),1102(dba) [rootrac1 ~]# id grid uid1101(grid) gid1101(oinstall) groups1101(oin…...

TCP-IP详解卷一:协议——阅读总结
该内容适合程序员查看 第1章 概述 1.1 引言 WAN全称是 Wide Area Network,中文名为广域网。 LAN全称是 Local Area Network,中文名为局域网。 1.2分层 ICP/IP协议族通常被认为是一个四层协议系统 分层协议应用层Telnet、FTP和e-mail运输层TCP和UDP网…...

【带源码】如何开发一个视频打赏,付费观看视频的系统?
【带源码】如何开发一个视频打赏,付费观看视频的系统?开发指南来了 最近非常火爆的视频打赏系统,有用户端,管理端,代理端 风口来了,系统部署简单,需要详细部署教程的可以留下评论哦!…...

Linux--进程的概念(一)
目录 一、冯诺依曼体系结构二、操作系统2.1 什么是操作系统2.2 操作系统的意义 三、进程3.1 进程的基本概念3.2 描述进程——PCB3.3 进程和程序的区别3.4 task_struct-PCB的一种3.5 task_struct的内容分类 四、如何查看进程4.1 通过系统文件查看进程4.2 通过ps指令查看进程 五、…...

大话设计模式——15.观察者模式(Observer Pattern)
简介 也称发布订阅模式(Publish/Subscribe),定义对象间的一种一对多的依赖关系,当一个对象的状态发生改变时,所有依赖于它的对象都得到通知并被自动更新 UML图: 应用场景: 消息通知组件&#x…...

LBE-LEX系列工业语音播放器|预警播报器|喇叭蜂鸣器的上位机配置操作说明
LBE-LEX系列工业语音播放器|预警播报器|喇叭蜂鸣器专为工业环境精心打造,完美适配AGV和无人叉车。同时,集成以太网与语音合成技术,为各类高级系统(如MES、调度系统、库位管理、立库等)提供高效便捷的语音交互体验。 L…...

装饰模式(Decorator Pattern)重构java邮件发奖系统实战
前言 现在我们有个如下的需求,设计一个邮件发奖的小系统, 需求 1.数据验证 → 2. 敏感信息加密 → 3. 日志记录 → 4. 实际发送邮件 装饰器模式(Decorator Pattern)允许向一个现有的对象添加新的功能,同时又不改变其…...
C++:std::is_convertible
C++标志库中提供is_convertible,可以测试一种类型是否可以转换为另一只类型: template <class From, class To> struct is_convertible; 使用举例: #include <iostream> #include <string>using namespace std;struct A { }; struct B : A { };int main…...

相机Camera日志实例分析之二:相机Camx【专业模式开启直方图拍照】单帧流程日志详解
【关注我,后续持续新增专题博文,谢谢!!!】 上一篇我们讲了: 这一篇我们开始讲: 目录 一、场景操作步骤 二、日志基础关键字分级如下 三、场景日志如下: 一、场景操作步骤 操作步…...
【ROS】Nav2源码之nav2_behavior_tree-行为树节点列表
1、行为树节点分类 在 Nav2(Navigation2)的行为树框架中,行为树节点插件按照功能分为 Action(动作节点)、Condition(条件节点)、Control(控制节点) 和 Decorator(装饰节点) 四类。 1.1 动作节点 Action 执行具体的机器人操作或任务,直接与硬件、传感器或外部系统…...

苍穹外卖--缓存菜品
1.问题说明 用户端小程序展示的菜品数据都是通过查询数据库获得,如果用户端访问量比较大,数据库访问压力随之增大 2.实现思路 通过Redis来缓存菜品数据,减少数据库查询操作。 缓存逻辑分析: ①每个分类下的菜品保持一份缓存数据…...

ETLCloud可能遇到的问题有哪些?常见坑位解析
数据集成平台ETLCloud,主要用于支持数据的抽取(Extract)、转换(Transform)和加载(Load)过程。提供了一个简洁直观的界面,以便用户可以在不同的数据源之间轻松地进行数据迁移和转换。…...

ardupilot 开发环境eclipse 中import 缺少C++
目录 文章目录 目录摘要1.修复过程摘要 本节主要解决ardupilot 开发环境eclipse 中import 缺少C++,无法导入ardupilot代码,会引起查看不方便的问题。如下图所示 1.修复过程 0.安装ubuntu 软件中自带的eclipse 1.打开eclipse—Help—install new software 2.在 Work with中…...

NFT模式:数字资产确权与链游经济系统构建
NFT模式:数字资产确权与链游经济系统构建 ——从技术架构到可持续生态的范式革命 一、确权技术革新:构建可信数字资产基石 1. 区块链底层架构的进化 跨链互操作协议:基于LayerZero协议实现以太坊、Solana等公链资产互通,通过零知…...
Web 架构之 CDN 加速原理与落地实践
文章目录 一、思维导图二、正文内容(一)CDN 基础概念1. 定义2. 组成部分 (二)CDN 加速原理1. 请求路由2. 内容缓存3. 内容更新 (三)CDN 落地实践1. 选择 CDN 服务商2. 配置 CDN3. 集成到 Web 架构 …...