Django-图片验证码和用户注册功能实现

1、图片验证码

在这里插入图片描述安装django-simple-captcha:

 pip install django-simple-captcha

设置setting将captcha添加到APP:
在这里插入图片描述
将生成的迁移文件应用到数据库:

 python manage.py migrate

在这里插入图片描述
添加路由:
在这里插入图片描述
新建forms.py文件创建表单模型:
在这里插入图片描述

修改视图函数:

在这里插入图片描述

在这里插入图片描述
编辑html文件:
在这里插入图片描述

效果:
在这里插入图片描述
设置当验证码错误时提示错误:
在这里插入图片描述
效果:
在这里插入图片描述

2、发送邮件,邮件注册

可以看到要发送邮件就要获取配置信息
在这里插入图片描述

打开163邮箱SMTP

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
修改settings文件:

在这里插入图片描述
进入shell交互界面:
在这里插入图片描述
查看邮件:
在这里插入图片描述
git:
在这里插入图片描述

编辑表单,定义注册:
在这里插入图片描述
实现注册功能:
在这里插入图片描述
编辑视图函数:
在这里插入图片描述
编辑html文件:
在这里插入图片描述

在这里插入图片描述
效果:
在这里插入图片描述
进行注册,输入已存在的用户名:

在这里插入图片描述

输入已存在的邮箱:
在这里插入图片描述
正常注册后返回登录界面,并且数据已经保存到数据库,可以正常登录:
在这里插入图片描述
注册时给密码加密:
在这里插入图片描述
在这里插入图片描述
新建py文件编辑:
在这里插入图片描述

在这里插入图片描述

在这里插入图片描述
注册一个用户查看数据库:
在这里插入图片描述
在这里插入图片描述
修改models.py文件:
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

修改admin.py文件,方便我们在后台修改和观察数据:
在这里插入图片描述
效果:
在这里插入图片描述
定义一个函数来发送邮件:
在这里插入图片描述

在这里插入图片描述

修改视图函数:
在这里插入图片描述
在这里插入图片描述
测试:注册一个用户,判断是否能够接收到邮件。
在这里插入图片描述
在路由配置文件中添加路由:
在这里插入图片描述

在这里插入图片描述
在这里插入图片描述

在这里插入图片描述

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
注册一个用户,不进行邮箱验证直接登录:
在这里插入图片描述
在settings文件中关闭时区:
在这里插入图片描述
访问邮箱的验证地址:
在这里插入图片描述

  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 3
    评论
要在Django实现图片验证码,可以按照以下步骤进行: 1. 安装Pillow库 Pillow库是Python Imaging Library(PIL)的升级版,用于处理图片。可以使用以下命令安装: ``` pip install Pillow ``` 2. 创建一个视图函数 在Django应用程序中,创建一个视图函数来生成图像验证码。以下是一个示例视图函数: ```python from django.http import HttpResponse from django.shortcuts import render from django.utils.six import BytesIO from PIL import Image, ImageDraw, ImageFont import random def create_captcha(request): # 设置验证码的宽度和高度 width, height = 100, 40 # 创建画布 im = Image.new('RGB', (width, height), 'white') # 获取画笔 draw = ImageDraw.Draw(im) # 定义字体大小 font_size = 25 # 定义字体颜色 font_color = (0, 0, 0) # 定义字体类型 font_type = 'arial.ttf' # 加载字体 font = ImageFont.truetype(font_type, font_size) # 定义验证码的字符集 captcha_str = 'ABCDEFGHIJKLMNOPQRSTUVWXYZ1234567890' # 生成随机字符串 captcha = ''.join(random.sample(captcha_str, 4)) # 将验证码存储到session中 request.session['captcha'] = captcha # 绘制验证码 for i in range(4): draw.text((10 + i * 20, 10), captcha[i], font=font, fill=font_color) # 生成图片 buf = BytesIO() im.save(buf, 'png') # 返回图片 return HttpResponse(buf.getvalue(), 'image/png') ``` 在上面的视图函数中,我们使用Pillow库生成一个白色画布,然后随机生成一个包含大写字母和数字的四位字符串作为验证码。我们将验证码存储在会话中,以便稍后验证。最后,我们使用BytesIO将图像保存为PNG格式,并将其作为HttpResponse返回。 3. 添加URL模式 在项目的urls.py文件中,添加一个URL模式来将请求路由到create_captcha视图函数: ```python from django.urls import path from . import views urlpatterns = [ # ... path('captcha/', views.create_captcha, name='captcha'), # ... ] ``` 4. 在模板中使用验证码 在表单中添加一个图像输入字段,以显示图像验证码。以下是一个示例模板代码: ```html <form method="post" action="{% url 'register' %}"> {% csrf_token %} <div class="form-group"> <label for="captcha">验证码:</label> <img src="{% url 'captcha' %}" alt="captcha"> <input type="text" name="captcha" class="form-control" id="captcha"> </div> <button type="submit" class="btn btn-primary">注册</button> </form> ``` 在上面的模板中,我们使用{% url %}模板标记来生成URL。我们还在图像标记中使用了一个alt属性,这将在图像无法显示时提供一个备用文本。 5. 验证验证码 在表单处理视图函数中,我们可以使用以下代码验证用户输入的验证码: ```python def register(request): if request.method == 'POST': form = RegistrationForm(request.POST) if form.is_valid(): # 验证验证码 captcha = request.POST.get('captcha', '') if captcha != request.session.get('captcha', ''): form.add_error(None, '验证码错误') return render(request, 'register.html', {'form': form}) # 处理表单数据 # ... else: # 处理表单无效的情况 # ... else: # 显示表单 # ... ``` 在上面的代码中,我们检查POST请求中的captcha字段是否与存储在会话中的验证码相匹配。如果不匹配,我们将表单标记为无效,并将错误消息添加到表单中。如果验证码是正确的,我们将处理表单数据。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值