时间:2021-05-22
日常在网站使用过程中经常遇到图形验证,今天准备自己做个图形验证码,这算是个简单的功能,也适合新手练习的,便于自己学习。
主要用到的库--PIL图像处理库,简单的思路,我们需要随机的颜色,随机的数字或字母,随机的线条、点作为干扰元素 拼凑成一张图片。
生成随机颜色,返回的是rgb三色。
def getRandomColor(): r = random.randint(0, 255) g = random.randint(0, 255) b = random.randint(0, 255) return (r, g, b)从数字、大小写字母里生成随机字符。
def getRandomChar(): random_num = str(random.randint(0, 9)) random_lower = chr(random.randint(97, 122)) # 小写字母a~z random_upper = chr(random.randint(65, 90)) # 大写字母A~Z random_char = random.choice([random_num, random_lower, random_upper]) return random_char图片操作,生成一张随机背景色的图片,随机生成5种字符+5种颜色,在图片上描绘字,由于默认的字体很小,还需要对字进行处理,不同系统下的字体文件存放位置不一样,这里我是把window下的 arial.ttf 字体复制到了当前文件夹下直接使用的。
# 图片宽高width = 160height = 50def createImg(): bg_color = getRandomColor() # 创建一张随机背景色的图片 img = Image.new(mode="RGB", size=(width, height), color=bg_color) # 获取图片画笔,用于描绘字 draw = ImageDraw.Draw(img) # 修改字体 font = ImageFont.truetype(font="arial.ttf", size=36) for i in range(5): # 随机生成5种字符+5种颜色 random_txt = getRandomChar() txt_color = getRandomColor() # 避免文字颜色和背景色一致重合 while txt_color == bg_color: txt_color = getRandomColor() # 根据坐标填充文字 draw.text((10 + 30 * i, 3), text=random_txt, fill=txt_color, font=font) # 打开图片操作,并保存在当前文件夹下 with open("test.png", "wb") as f: img.save(f, format="png")这个时候可以看到文件夹下面的图片
这里是张很清晰的图片,为了有干扰元素,这里还需要在图片加入些线条、点作为干扰点。
随机画线,在图片宽高范围内随机生成2个坐标点,并通过随机颜色产生线条。
def drawLine(draw): for i in range(5): x1 = random.randint(0, width) x2 = random.randint(0, width) y1 = random.randint(0, height) y2 = random.randint(0, height) draw.line((x1, y1, x2, y2), fill=getRandomColor())随机画点,随机生成横纵坐标点。
def drawPoint(draw): for i in range(50): x = random.randint(0, width) y = random.randint(0, height) draw.point((x,y), fill=getRandomColor())生成方法
def createImg(): bg_color = getRandomColor() # 创建一张随机背景色的图片 img = Image.new(mode="RGB", size=(width, height), color=bg_color) # 获取图片画笔,用于描绘字 draw = ImageDraw.Draw(img) # 修改字体 font = ImageFont.truetype(font="arial.ttf", size=36) for i in range(5): # 随机生成5种字符+5种颜色 random_txt = getRandomChar() txt_color = getRandomColor() # 避免文字颜色和背景色一致重合 while txt_color == bg_color: txt_color = getRandomColor() # 根据坐标填充文字 draw.text((10 + 30 * i, 3), text=random_txt, fill=txt_color, font=font) # 画干扰线点 drawLine(draw) drawPoint(draw) # 打开图片操作,并保存在当前文件夹下 with open("test.png", "wb") as f: img.save(f, format="png")最终生成的图片
这里介绍的是图片生成的方法,可以将图片直接显示在前端,也可以使用接口返回url。用Django做的,需要注意的是图片保存的路径。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
前言本文介绍的imagecode方法是一个生成图形验证码的请求,checkcode方法实现了对这个图形验证码的验证。从验证码的生成到验证的过程中,验证码是通过S
php生成验证码的函数,实用靠谱。先上下生成的验证码的效果图(这里生成的是全数字的验证码的示例效果):下面是php生成验证码的源码:
图形化验证码生成和验证功能介绍在使用用户名和密码登录功能时,需要填写验证码,验证码是以图形化的方式进行获取和展示的。验证码使用原理验证码的使用流程和原理为:在服
本文介绍了SpringBoot结合SpringSecurity实现图形验证码功能,分享给大家,具体如下:生成图形验证码根据随机数生成图片将随机数存到Sessio
本文实例讲述了asp.net使用ashx生成图形验证码的方法。分享给大家供大家参考,具体如下:验证码的好处不用我多说,你们都懂的。我在网上看到有人把验证码直接写