[oldboy-django][2深入django]登录注册页面验证码

后台生成随机验证码

#验证码生成

    - 在login.html 中有一张验证码图片
      设置图片的src url, 相当于发送一次get请求,返回的内容为图片渲染的内容

            <div class="col-sm-5">
                <input type="password" class="form-control" id="inputPassword3" placeholder="验证码">
            </div>
            <div class="col-sm-5">
                <img src="/check_code/" width="150px" height="34px" title="点击刷新验证码">
            </div>

    - 随机生成图片内容

        def check_code(request):
            from PIL import Image,ImageDraw
            from io import BytesIO
            f = BytesIO() # 从内存开辟一段空间
            img = Image.new(mode="RGB", size=(150,34), color=(255, 255, 255))
            draw = ImageDraw.Draw(img, mode=‘RGB‘)

            # 设置图片文本的字体
            from PIL import ImageFont
            font = ImageFont.truetype("kumo.ttf", 25)

            #7 往图片添加内容设置每个字符不同的颜色
            import random
            code_list = []
            for i in range(5):
                char = chr(random.randint(65,90))
                code_list.append(char)
                draw.text((i*20,10), char,
                          fill=(random.randint(0,255),random.randint(0,255),random.randint(0,255)),
                          font = font
                          )
            # 添加内容结束
            img.save(f,‘png‘) # 图片内容保存到内存中
            data = f.getvalue() # 读取图片内容
            return  HttpResponse(data)

将验证码保存在session, 用户提交验证码和session的验证码进行比较,完成验证码的验证

    - 将验证码保存在session,用来记住用户。以便后面的验证码验证
        code = "".join(code_list)
        request.session["code"] = code

    - login验证码验证
        def login(request):
            if request.method == ‘GET‘:
                return render(request, ‘login.html‘)
            else:
                input_code = request.POST.get("code")
                session_code = request.session.get(‘code‘)
                if input_code.upper() == session_code.upper():
                    return  HttpResponse("code is correct")
                else:
                    return HttpResponse("code is invalid")

将验证码封装

- 验证码封装
        import random
        from PIL import (Image,ImageDraw,ImageFont,ImageFilter)

        def check_code(width=120, height=30, char_length=5, font_file=‘kumo.ttf‘, font_size=28):
        code = []
        img = Image.new(mode=‘RGB‘, size=(width, height), color=(255, 255, 255))
        draw = ImageDraw.Draw(img, mode=‘RGB‘)

        def rndChar():
            """生成随机字母    :return:
            """
            return chr(random.randint(65, 90))

        def rndColor():
            """生成随机颜色:return:
            """
            return (random.randint(0, 255), random.randint(10, 255), random.randint(64, 255))
        # 写文字
        font = ImageFont.truetype(font_file, font_size)
        for i in range(char_length):
            char = rndChar()
            code.append(char)
            h = random.randint(0, 4)
            draw.text([i * width / char_length, h], char, font=font, fill=rndColor())

        # 写干扰点
        for i in range(40):
            draw.point([random.randint(0, width), random.randint(0, height)], fill=rndColor())

        # 写干扰圆圈
        for i in range(40):
            draw.point([random.randint(0, width), random.randint(0, height)], fill=rndColor())
            x = random.randint(0, width)
            y = random.randint(0, height)
            draw.arc((x, y, x + 4, y + 4), 0, 90, fill=rndColor())

        # 画干扰线
        for i in range(5):
            x1 = random.randint(0, width)
            y1 = random.randint(0, height)
            x2 = random.randint(0, width)
            y2 = random.randint(0, height)
            draw.line((x1, y1, x2, y2), fill=rndColor())

        img = img.filter(ImageFilter.EDGE_ENHANCE_MORE)
        return img, ‘‘.join(code)

获取验证码后台视图

# 封装后的使用

    def checkout(request):
        from io import BytesIO
        from utils.checkCode import check_code
        img, code = check_code()
        stream = BytesIO()
        img.save(stream, ‘png‘)
        request.session[‘code‘] = code
        return HttpResponse(stream.getvalue())

时间: 2024-08-29 06:27:41

[oldboy-django][2深入django]登录注册页面验证码的相关文章

路飞项目搭建3 TODO注释, 自定义模态框, vue-cookies操作浏览器cookies, 腾讯云短信开发, 代码(登录注册页面,多方式登录,手机是否存在验证接口,腾讯短信开发)

TODO注释 """ 作用:todo是一种特殊的注释,书写就是 # TODO 注释内容,可以在TODO控制台面板快速定位注释位置 """ 自定义模态框 componses/Login.vue <template> <div class="login"> <span @click="close_login">x</span> </div> </

unity 登录注册页面数据传递(无数据库)

unity  登录注册页面数据传递(无数据库) 继上一篇随笔.制作unity登录注册页面. 创建一下脚本: 新建脚本"goa"(存储全局变量方便其他脚本的调用): using UnityEngine;using System.Collections; public class goa : MonoBehaviour { //用户名    public const string name = "M_name";    //密码    public const stri

登录注册页面实现

多种登录注册页面实现 前后端语言实现用户注册功能 php注册登录系统 原文地址:https://www.cnblogs.com/knuzy/p/9248539.html

django + vue 简单配置登录注册及分页和实例化

django基本跨域知识点 setting设置 ALLOWED_HOSTS = ['*']??INSTALLED_APPS = [   'django.contrib.admin',   'django.contrib.auth',   'django.contrib.contenttypes',   'django.contrib.sessions',   'django.contrib.messages',   'django.contrib.staticfiles',   'app',  

node.js实现简单的登录注册页面

首先需要新建四个文件 一个服务器js 一个保存数据的txt 一个登陆.一个注册页面html 1.注册页面 <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>regist</title> </head> <body> <div> <label for="us

php做登录注册页面及加载

//SQL注入攻击 //1.过滤用户的输入 //2.使用预处理语句 //3.写代码的时候尽量避免 1 <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> 2 <html xmlns="http://www.w3.org/1999/xhtml"

php登录注册页面及加载

                       php注册界面                               <h1>注册页面</h1> <form action="./zhucechuli.php" method="post"> <div>用户名:<input type="text" name="uid" /></div> <div&g

javaweb登录注册页面;

初学javaweb,第一个要做的项目就是登陆注册页面,被这两个页面折磨了两天,终于写出来了,相信也会有许多初学者会面临着写这个页面的问题,给大家提供一段代码,仅供参考. 登录页面: <form action="in.jsp" method="post"> <input type="hidden" name="hidden" value="deng"> <table> &l

php登录注册页面

一.注册页面 1.首先要用form表单做一个注册页面: <h1>注册</h1> <form action="chuli.php" method="post"> <div>用户名:<input type="text" name="uid" /></div> <div>密码:<input type="password" n