时间:2021-05-19
1.导入模块 并定义一个验证状态
from PIL import Image, ImageDraw, ImageFontfrom django.utils.six import BytesIOdef verify_code(request): #引入随机函数模块 import random #定义变量,用于画面的背景色、宽、高 bgcolor = (random.randrange(20, 100), random.randrange( 20, 100), 255) width = 100 height = 25 #创建画面对象 im = Image.new('RGB', (width, height), bgcolor) #创建画笔对象 draw = ImageDraw.Draw(im) #调用画笔的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) #定义验证码的备选值 str1 = 'ABCD123EFGHIJK456LMNOPQRS789TUVWXYZ0' #随机选取4个值作为验证码 rand_str = '' for i in range(0, 4): rand_str += str1[random.randrange(0, len(str1))] #构造字体对象,ubuntu的字体路径为“/usr/share/fonts/truetype/freefont” font = ImageFont.truetype('FreeMono.ttf', 23) #构造字体颜色 fontcolor = (255, random.randrange(0, 255), random.randrange(0, 255)) #绘制4个字 draw.text((5, 2), rand_str[0], font=font, fill=fontcolor) draw.text((25, 2), rand_str[1], font=font, fill=fontcolor) draw.text((50, 2), rand_str[2], font=font, fill=fontcolor) draw.text((75, 2), rand_str[3], font=font, fill=fontcolor) #释放画笔 del draw #存入session,用于做进一步验证 request.session['verifycode'] = rand_str #内存文件操作 buf = BytesIO() #将图片保存在内存中,文件类型为png im.save(buf, 'png') #将内存中的图片数据返回给客户端,MIME类型为图片png return HttpResponse(buf.getvalue(), 'image/png')3.在网页中直接放入img中
<img src="/verify_code/" alt="验证码">
4.使用ajax 获取验证密码和账号
<!DOCTYPE html><html lang="en"><head> <meta charset="UTF-8"> <title>login</title></head><body><h1 class="show"></h1><input type="text" id = username value="{{username}}"> <br><input type="text" id = password> <br><input type="text" id = yum> <a>请输入验证码</a> <br><img src="/verify_code/" alt="验证码"><input type="button" id="Ajax" value="ajax登陆"> <br><input type="checkbox" id = "ow" name="ow"> 记住密码<br><a href="/get_cookies">点击到获取cookies</a></body><script src="/static/index/js/jquery-3.3.1.min.js"></script></html><script> $(function () { $('#Ajax').click(function () { username = $('#username').val(); password = $('#password').val(); ow = $("#ow").val(); yum = $('#yum').val(); $.ajax({ 'url': '/loginajax', 'type': 'post', 'data': {'username': username, 'password': password, "yum":yum,}, 'success':function(data){ //登陆成功返回1 //登陆失败返回0 //验证失败返回3 if (data.res == 1) { $('.show').show().html('登陆成功') } else if (data.res == 0) { $('.show').show().html('登陆失败') } else if (data.res == 3){ $('.show').show().html('验证码输入失败') } } }); }); });</script>在上面 ajax 中 向服务器发送了 账号密码 和 验证码
在验证函数中
yzm = request.POST.get('yum') # 获取传入的 验证码 vaue = request.session['verifycode'] # 生成图片的时候 把验证码存到了session 中 if yzm !=vaue: #如果不相等的话会返回 3 HTML ajax 会显示验证错误 return JsonResponse({'res':3})成果图:
总结
以上所述是小编给大家介绍的django 利用pillow 进行简单的设置验证码功能(python),希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对网站的支持!
如果你觉得本文对你有帮助,欢迎转载,烦请注明出处,谢谢!
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
使用Python的pillow模块random模块随机生成验证码图片,并应用到Django项目中安装pillow$pip3installpillow生成验证码图
前言Pillow库有很多用途,本文使用Pillow来生成随机的验证码图片。Pillow的用法参考:验证码是随机的,使用Python内置的random库来生成随机
django-simple-captcha是django的验证码包,非常简单实用,这次记录的是如何点击验证码后刷新验证码,因为这个功能官方文档并没有详细给出。d
Python3使用pillow库生成随机验证码的代码如下所示:importrandom#pillow包的使用fromPILimportImage,ImageDr
使用python生成随机图片验证码,需要使用pillow模块1.安装pillow模块pipinstallpillow2.pillow模块的基本使用1.创建图片f