当前位置:脚本大全 > > 正文

django session验证(Django框架验证码用法实例分析)

时间:2021-10-04 01:50:44类别:脚本大全

django session验证

Django框架验证码用法实例分析

本文实例讲述了django框架验证码用法。分享给大家供大家参考,具体如下:

验证码

1、作用

2、业务流程

绘制验证码图片

  • ?
  • 1
  • background = (10,20,30) // rgb颜色
  • 初始化画布

  • ?
  • 1
  • image = image.new(‘rgb',(100,50),background)
  • 获取画布中画笔对象

  • ?
  • 1
  • draw = imagedraw.draw(image)
  • 绘制验证码,随机四个

  • ?
  • 1
  • 2
  • 3
  • font = imagefont.truetype(‘path',size)
  • fontcolor = (20,40,60)
  • draw.text((x,y),'r',font,fontcolor)
  • 返回验证码内容

  • ?
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • # 删除画笔
  • del draw
  • #保存图片到bytesio对象
  • import io
  • buf = io.bytesio()
  • image.save(buf,'png')
  • #返回bytesio中的内容
  • return httpresponse(buf.getvalue(),'image/png')
  • 3、代码范例

    html页面

  • ?
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23
  • 24
  • 25
  • 26
  • 27
  • 28
  • <form method="post" action="{% url 'sitesapp:login' %}">
  •   {% csrf_token %}
  •     <li class="login">
  •       <li class="input-group">
  •        <span class="input-group-addon" id="basic-addon1">用户名</span>
  •        <input type="text" class="form-control" placeholder="username" aria-describedby="basic-addon1" name="uname">
  •       </li>
  •       <li class="input-group">
  •        <span class="input-group-addon" id="basic-addon1">密    码</span>
  •        <input type="text" class="form-control" placeholder="password" aria-describedby="basic-addon1" name="upswd">
  •       </li>
  •       <li class="input-group">
  •        <span class="input-group-addon" id="basic-addon1">验证码</span>
  •        <input type="text" class="form-control" placeholder="auth code" aria-describedby="basic-addon1" name="ucode">
  •       </li>
  •       <li class="vcode">
  •         <img src="/app/getvcode/" id="vcode">
  •       </li>
  •       <input type="submit" class="loginbtn" value="登 录"><br>
  •     </li>
  •   </form>
  •   <script type="text/javascript">
  •     $(function () {
  •       $('#vcode').click(function () {
  •         $(this).attr('src',"/app/getvcode"+math.random())
  •       })
  •     })
  •   </script>
  • views视图

  • ?
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23
  • 24
  • 25
  • 26
  • 27
  • 28
  • 29
  • 30
  • 31
  • 32
  • 33
  • 34
  • 35
  • 36
  • 37
  • '''
  • 生成并返回验证码
  • '''
  • def getvcode(request):
  •   # 随机生成验证码
  •   population = string.ascii_letters+string.digits
  •   letterlist = random.sample(population,4)
  •   vcode = ''.join(letterlist)
  •   # 保存该用户的验证码
  •   request.session['vcode']=vcode
  •   # 绘制验证码
  •   # 需要画布,长宽颜色
  •   image = image.new('rgb',(176,60),color=getrandomcolor())
  •   # 创建画布的画笔
  •   draw = imagedraw.draw(image)
  •   # 绘制文字,字体所在位置
  •   path = os.path.join(base_dir,'static','fonts','adobearabic-bolditalic.otf')
  •   font = imagefont.truetype(path,50)
  •   for i in range(len(vcode)):
  •     draw.text((20+40*i,0),vcode[i],fill=getrandomcolor(),font=font)
  •   # 添加噪声
  •   for i in range(500):
  •     position = (random.randint(0,176),random.randint(0,50))
  •     draw.point(position,fill=getrandomcolor())
  •   # 返回验证码字节数据
  •   # 创建字节容器
  •   buffer = io.bytesio()
  •   # 将画布内容丢入容器
  •   image.save(buffer,'png')
  •   # 返回容器内的字节
  •   return httpresponse(buffer.getvalue(),'image/png')
  • # 获取随机颜色
  • def getrandomcolor():
  •   red = random.randint(0,255)
  •   green = random.randint(0,255)
  •   blue = random.randint(0,255)
  •   return (red,green,blue)
  • 希望本文所述对大家基于django框架的python程序设计有所帮助。

    原文链接:https://blog.csdn.net/lm_is_dc/article/details/80527830

    标签:
    上一篇下一篇

    猜您喜欢

    热门推荐