四. Django项目之电商购物商城 -- 图片验证码生成

本文涉及的产品
云数据库 Tair(兼容Redis),内存型 2GB
Redis 开源版,标准版 2GB
推荐场景:
搭建游戏排行榜
简介: 四. Django项目之电商购物商城 -- 图片验证码生成

Django项目之电商购物商城 – 图片验证码生成

需要开发文档和前端资料的可私聊

一. 图片验证码的生成

1. 创建应用用于生成图片验证码 , 以及短信验证码

python manage.py startapp verfications

2.配置radis数据库

"var_code":{
        # 配置数据库指定引擎
        "BACKEND" : "django_redis.cache.RedisCache",
        # 配置使用 Redis 的数据库名称
        "LOCATION" : "redis://127.0.0.1:6379/2",
        "OPTIONS":{
            "CLIENT_CLASS" : "django_redis.client.DefaultClient"
        }
    },

3.认证应用 , 分发路由 , 创建路由

认证app

'verfications.apps.VerficationsConfig',

分发路由

path('', include('verfications.urls')),

创建验证码路由

re_path('^image_code/(?P<uuid>[\w-]+)/$' , views.ImageCodeView.as_view())

4. 生成图片验证码

from random import randint , choice
from PIL import Image , ImageDraw , ImageFont
import io , os
# 制作随机验证码:数字,大小写字母
def get_random_code():
    # 随机数字
    number = str(randint(0,9))
    # 随机大写字母
    upper = chr(randint(65 , 90))
    # 随机小写字母
    lower = chr(randint(97, 122))
    # 再大小写字母和数字中再随机获取一个
    code = choice([number , upper , lower])
    return code
# 获取随机颜色
def get_color():
    return (randint(0,255),randint(0,255),randint(0,255))
# 制作图片
def create_img():
    # 创建图片对象
    img = Image.new(mode='RGB' , size=(90 , 30),color=get_color())
    # 创建画笔工具
    draw = ImageDraw.Draw(img)
    # 制作图片噪点
    # 噪点
    for i in range(60):
        # point([xy:图片的坐标] , fill颜色)
        draw.point([randint(0,150) , randint(0,30)] , fill=get_color())
    # 噪线
    for i in range(8):
        # line([xy:图片的坐标] , fill颜色)
        draw.line([randint(0,150) , randint(0,30),randint(0,150) , randint(0,30)] , fill=get_color())
    # 圆,弧线
    x = randint(0, 150)
    y = randint(0,15)
    for i in range(5):
        draw.arc([ x,y ,x*2 , y*2] ,0, 90 ,fill=get_color() )
    # 设置字体 , 导入字体文件 , 设置字体大小
    dir = os.path.join(os.path.dirname(__file__) , 'fonts','Arial.ttf')
    font = ImageFont.truetype(dir,24)
    # 拼接生成的验证码
    text = ''
    # 生成验证码
    for i in range(4):
        c = get_random_code()
        # 将获取到的验证码字符写入到图片中
        draw.text((10+20*i , 2) , text=c , fill=get_color() , font=font)
        text += c
    # 将图片保存到内存中
    out = io.BytesIO()
    # 保证验证码的图片
    img.save(out , format='png')
    return out.getvalue() , text
if __name__ == '__main__':
    img , text = create_img()
    print(text)

4. 创建相应视图

在登录的js代码中会生成uuid作为图片验证码的url , 从而避免在多人注册的情况下生成的验证码被覆盖

from django.shortcuts import render , HttpResponse
from django.views import View
from verfications.PictureCode import CodeImg
from django_redis import get_redis_connection
# Create your views here.
class ImageCodeView(View):
  # 获得uuid的参数
    def get(self , request , uuid):
        # 获得验证码 以及图片
        image , code = CodeImg.create_img()
        # 将数据保存到redis数据库
        redis_conn = get_redis_connection('var_code')
        redis_conn.setex(f'image_{uuid}' , 60 , code)
        return HttpResponse(image , content_type='image/png')

修改前端代码 , 绑定相关方法

<li>
    <label>图形验证码:</label>
    <input type="text" name="image_code" id="pic_code" class="msg_input"
    v-model="image_code" @blur="check_image_code">
    <img v-bind:src="image_code_url" alt="图形验证码" class="pic_code"
    @click="generate_image_code">
    <span class="error_tip" v-show="error_image_code">请填写图形验证码</span>
</li>


相关实践学习
基于Redis实现在线游戏积分排行榜
本场景将介绍如何基于Redis数据库实现在线游戏中的游戏玩家积分排行榜功能。
云数据库 Redis 版使用教程
云数据库Redis版是兼容Redis协议标准的、提供持久化的内存数据库服务,基于高可靠双机热备架构及可无缝扩展的集群架构,满足高读写性能场景及容量需弹性变配的业务需求。 产品详情:https://www.aliyun.com/product/kvstore &nbsp; &nbsp; ------------------------------------------------------------------------- 阿里云数据库体验:数据库上云实战 开发者云会免费提供一台带自建MySQL的源数据库&nbsp;ECS 实例和一台目标数据库&nbsp;RDS实例。跟着指引,您可以一步步实现将ECS自建数据库迁移到目标数据库RDS。 点击下方链接,领取免费ECS&amp;RDS资源,30分钟完成数据库上云实战!https://developer.aliyun.com/adc/scenario/51eefbd1894e42f6bb9acacadd3f9121?spm=a2c6h.13788135.J_3257954370.9.4ba85f24utseFl
相关文章
|
3月前
|
机器学习/深度学习 人工智能 算法
植物病害识别系统Python+卷积神经网络算法+图像识别+人工智能项目+深度学习项目+计算机课设项目+Django网页界面
植物病害识别系统。本系统使用Python作为主要编程语言,通过收集水稻常见的四种叶片病害图片('细菌性叶枯病', '稻瘟病', '褐斑病', '稻瘟条纹病毒病')作为后面模型训练用到的数据集。然后使用TensorFlow搭建卷积神经网络算法模型,并进行多轮迭代训练,最后得到一个识别精度较高的算法模型,然后将其保存为h5格式的本地模型文件。再使用Django搭建Web网页平台操作界面,实现用户上传一张测试图片识别其名称。
142 22
植物病害识别系统Python+卷积神经网络算法+图像识别+人工智能项目+深度学习项目+计算机课设项目+Django网页界面
|
2月前
|
JavaScript 前端开发 Python
django接收前端vue传输的formData图片数据
django接收前端vue传输的formData图片数据
62 4
|
3月前
|
机器学习/深度学习 算法 TensorFlow
交通标志识别系统Python+卷积神经网络算法+深度学习人工智能+TensorFlow模型训练+计算机课设项目+Django网页界面
交通标志识别系统。本系统使用Python作为主要编程语言,在交通标志图像识别功能实现中,基于TensorFlow搭建卷积神经网络算法模型,通过对收集到的58种常见的交通标志图像作为数据集,进行迭代训练最后得到一个识别精度较高的模型文件,然后保存为本地的h5格式文件。再使用Django开发Web网页端操作界面,实现用户上传一张交通标志图片,识别其名称。
126 6
交通标志识别系统Python+卷积神经网络算法+深度学习人工智能+TensorFlow模型训练+计算机课设项目+Django网页界面
|
3月前
|
机器学习/深度学习 人工智能 算法
【新闻文本分类识别系统】Python+卷积神经网络算法+人工智能+深度学习+计算机毕设项目+Django网页界面平台
文本分类识别系统。本系统使用Python作为主要开发语言,首先收集了10种中文文本数据集("体育类", "财经类", "房产类", "家居类", "教育类", "科技类", "时尚类", "时政类", "游戏类", "娱乐类"),然后基于TensorFlow搭建CNN卷积神经网络算法模型。通过对数据集进行多轮迭代训练,最后得到一个识别精度较高的模型,并保存为本地的h5格式。然后使用Django开发Web网页端操作界面,实现用户上传一段文本识别其所属的类别。
112 1
【新闻文本分类识别系统】Python+卷积神经网络算法+人工智能+深度学习+计算机毕设项目+Django网页界面平台
|
2月前
|
数据采集 自然语言处理 Python
用 Python 生成并识别图片验证码
用 Python 生成并识别图片验证码
53 1
|
3月前
|
Linux Python
解决django项目报错很离谱的报错之RuntimeError: populate() isn't reentrant
解决django项目报错很离谱的报错之RuntimeError: populate() isn't reentrant
|
3月前
|
机器学习/深度学习 人工智能 算法
【果蔬识别系统】Python+卷积神经网络算法+人工智能+深度学习+计算机毕设项目+Django网页界面平台
【果蔬识别系统】Python+卷积神经网络算法+人工智能+深度学习+计算机毕设项目+Django网页界面平台。果蔬识别系统,本系统使用Python作为主要开发语言,通过收集了12种常见的水果和蔬菜('土豆', '圣女果', '大白菜', '大葱', '梨', '胡萝卜', '芒果', '苹果', '西红柿', '韭菜', '香蕉', '黄瓜'),然后基于TensorFlow库搭建CNN卷积神经网络算法模型,然后对数据集进行训练,最后得到一个识别精度较高的算法模型,然后将其保存为h5格式的本地文件方便后期调用。再使用Django框架搭建Web网页平台操作界面,实现用户上传一张果蔬图片识别其名称。
69 0
【果蔬识别系统】Python+卷积神经网络算法+人工智能+深度学习+计算机毕设项目+Django网页界面平台
|
2月前
|
前端开发 数据库 Python
Django自带图形验证码 django-simple-captcha
Django自带图形验证码 django-simple-captcha
35 0
|
3月前
|
存储 NoSQL Java
|
4月前
|
存储 监控 开发工具
Django 后端架构开发:手机与邮箱验证码接入、腾讯云短信SDK和网易邮箱
Django 后端架构开发:手机与邮箱验证码接入、腾讯云短信SDK和网易邮箱
78 0