验证码功能

验证码功能

1.安装captcha插件

(dj_login) D:\dj\dj_login>pip install django-simple-captcha
Collecting django-simple-captchaUsing cached https://files.pythonhosted.org/packages/d7/f4/ea95b04ed3abc7bf225716f17e35c5a185f6100db4d7541a
46696ce40351/django-simple-captcha-0.5.9.zip
Requirement already satisfied: six>=1.2.0 in e:\venv\dj_login\lib\site-packages (from django-simple-captcha)
(1.11.0)
Requirement already satisfied: Django>=1.8 in e:\venv\dj_login\lib\site-packages (from django-simple-captcha)(1.11.12)
Collecting Pillow!=5.1.0,>=2.2.2 (from django-simple-captcha)Using cached https://files.pythonhosted.org/packages/1b/50/869910cd7110157fbefd0fed3db3656c1951f1bceecdd00e
3716aa269609/Pillow-5.2.0-cp36-cp36m-win_amd64.whl
Collecting django-ranged-response==0.2.0 (from django-simple-captcha)Using cached https://files.pythonhosted.org/packages/70/e3/9372fcdca8e9c3205e7979528ccd1a14354a9a24d38efff1
1c1846ff8bf1/django-ranged-response-0.2.0.tar.gz
Requirement already satisfied: pytz in e:\venv\dj_login\lib\site-packages (from Django>=1.8->django-simple-captcha) (2018.5)
Installing collected packages: Pillow, django-ranged-response, django-simple-captchaRunning setup.py install for django-ranged-response ... doneRunning setup.py install for django-simple-captcha ... done
Successfully installed Pillow-5.2.0 django-ranged-response-0.2.0 django-simple-captcha-0.5.9

2.注册captcha并创建表

INSTALLED_APPS = ['django.contrib.admin','django.contrib.auth','django.contrib.contenttypes','django.contrib.sessions','django.contrib.messages','django.contrib.staticfiles','app_login','xadmin','crispy_forms','captcha'
](dj_login) D:\dj\dj_login>python manage.py migrate
Operations to perform:Apply all migrations: admin, app_login, auth, captcha, contenttypes, sessions, xadmin
Running migrations:Applying captcha.0001_initial... OK

3.添加路由

from django.conf.urls import url
from django.conf.urls import include
import xadminurlpatterns = [# path('admin/', admin.site.urls),url('xadmin/',xadmin.site.urls),url(r'',include('app_login.urls')),url(r'^captcha',include('captcha.urls'))
]

4.修改forms.py表单

from django import forms   #导入forms模块
from captcha.fields import CaptchaField   #导入验证码功能模块class UserForm(forms.Form):   #所有表单类都需要继承forms.Form'''
定义form子标签<input>子元素的name属性变量,这里定义的是name=username和name=password的变量
label就是label标签,max_length为设置该变量可以输入的最大字符
widget为设置input的类型,这里的passwordinput为type='password',添加属性使用attrs={}以字典键值对的形式,这里增加了class和placeholder属性
'''username=forms.CharField(label='用户名',max_length=128,widget=forms.TextInput(attrs={'class':'form-control','placeholder':'用户名'}))password=forms.CharField(label='密码',max_length=512,widget=forms.PasswordInput(attrs={'class':'form-control','placeholder':'密码'}))captcha=CaptchaField(label='验证码')   #添加验证码表单字段

5.修改login.html文件

{% extends 'base.html' %}  <!--继承base网页模板内容,可以浏览网页查看效果-->
{% load staticfiles %}   <!--载入静态方法,用于加载static中的文件-->
{% block title %}登陆{%  endblock %}  <!--设置title,默认使用base模板中的-->
{% block css %}<link href="{% static 'css/login.css'%}" rel="stylesheet" />{% endblock %} <!--使用自定义的css登陆样式,不用base中的-->{% block content %}   <!--该模板语言用于定义主体内容,和模板中的结合使用--><div class="container"><div class="col-md-4 col-md-offset-4"><form class='form-login' action="/login/" method="POST">{% if message %}      <!--类似if语句--><div class="alert alert-warning">{{ message }}</div>  <!--使用bootstrap的警示传递message信息-->{% endif %}{% csrf_token %}<h2 class="text-center">欢迎登录</h2><div class="form-group">{{ login_form.username.label_tag }}{{ login_form.username}}</div><div class="form-group">{{ login_form.password.label_tag }}{{ login_form.password }}</div><div class="form-group">{{ login_form.captcha.errors }}   <!--当验证码输入不正确时显示-->{{ login_form.captcha.label_tag }}  <!--用于表示label的页面显示-->{{ login_form.captcha }}            <!--用于captcha的input标签显示--></div>
{#              <div class="form-group">#}
{#                <label for="id_username">用户名:</label>#}
{#                <input type="text" name='username' class="form-control" id="id_username" placeholder="Username" autofocus required>#}
{#              </div>#}
{#              <div class="form-group">#}
{#                <label for="id_password">密码:</label>#}
{#                <input type="password" name='password' class="form-control" id="id_password" placeholder="Password" required>#}
{#              </div>#}<button type="reset" class="btn btn-default pull-left">重置</button><button type="submit" class="btn btn-primary pull-right">提交</button></form></div></div> <!-- /container -->
{% endblock %}

6.查看效果

705271-20181005140407938-1987230957.png

705271-20181005140419238-473494668.png

转载于:https://www.cnblogs.com/endmoon/p/9744746.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/250559.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Java 类的成员

Java 类的成员 初始化块 1、一个类中初始化块若有修饰符&#xff0c;则只能被static修饰&#xff0c;称为静态代码块(staticblock )&#xff0c;当类被载入时&#xff0c;类属性的声明和静态代码块先后顺序被执行&#xff0c;且只被执行一次。 2、static块通常用于初始化sta…

linux --- 进阶指令

进阶指令(重点) 1、df 指令 作用: 查看磁盘空间语法: # df -h 注: -h:以较高可读性的方式展示出来 2、free 指令 作用: 查看内存使用情况语法: # free -m 注: -m:以M的单位显示内存情况 -/ buffers/cache: free 代表真实可用的内存为 486 Mb Swap: 表示,临时将硬盘当作内存…

MFC对话框播放8位512*512的像素数据

关键代码&#xff1a; UINT playAllFrame(LPVOID lpParameter){//showOneFrame(0,TRUE);CMFCDialogDlg *mydlg (CMFCDialogDlg *) lpParameter;//获取原始数据文件CString selectPath;mydlg->GetDlgItemTextW(IDC_MFCEDITBROWSE,selectPath);string StrSelectPath(CW2A(sel…

java 集合 CopyOnWriteArrayList

CopyOnWriteArrayList 也是实现List接口他是在concurrent 包里面&#xff0c;所以他是线程安全的&#xff0c;其他的基本和ArrayList很想。他线程安全是用ReentrantLock 实现的&#xff0c;他内部有一个ReentrantLock对象&#xff0c;然后在增删改的时候都操作这个锁对象&#…

Java 类的特性1

Java 类的特性1 继承 1.为什么要有继承&#xff1f; 多个类中存在相同属性和行为时&#xff0c;将这些内容抽取到单独一个类中&#xff0c;那么多个类无需再定义这些属性和行为&#xff0c;只要继承那个类即可。 2.此处的多个类称为子类&#xff0c;单独的这个类称为父类&a…

linux --- 高级指令

高级指令 1、hostname 指令 作用: 操作(读取|操作)服务器的主机名语法1: # hostname (输出完整的主机名) 语法2: # hostname -f (输出当前主机中的FQDN) FQDN&#xff1a;(Fully Qualified Domain Name)全限定域名&#xff1a;同时带有主机名和域名的名称。 2、id 指令 作…

Linux修改密码后不能SSH远程登录了

1、把以下文件的属性改成755&#xff0c;然后再修改密码&#xff1a;/etc/passwd ,/etc/group , /etc/shadow , /etc/gshadow2、如果文件的属性无法更改&#xff0c;请用lsattr 查看文件是否有 i 属性&#xff0c;如有&#xff0c;则用chattr取消之&#xff0c;如&#xff1a;l…

Java 类的特性2

Java 类的特性2 类属性、类方法的设计思想 类属性作为该类各个对象之间共享的变量。在设计类时,分析哪些类属性不因对象的不同而改变&#xff0c;将这些属性设置为类属性。相应的方法设置为类方法。如果方法与调用者无关&#xff0c;则这样的方法通常被声明为类方法&#xff…

docker --- 镜像、容器

Docker使用国内的源 windows下使用 "everything"软件 查找 daemon.json修改为如下: {"registry_mirrors": ["https://docker.mirrors.ustc.edu.cn"] }查看images(镜像) docker images注: 看见的镜像是已经下载好的,因此在没有网络的情况下也可…

Java 面向对象

Java 面向对象 面向对象的三大特征 封装 (Encapsulation)继承 (Inheritance)多态 (Polymorphism) 类的访问机制&#xff1a; 在一个类中的访问机制&#xff1a;类中的方法可以直接访问类中的成员变量。&#xff08;例外&#xff1a;static方法访问非static&#xff0c;编译…

交换机老化测试和性能测试方法收集

说明&#xff1a;这是一个做交换机朋友给的一个方法&#xff0c;只做老化测试&#xff0c;不做压力满载测试。 我所理解的&#xff1a;老化测试是指在一定的时间内工作负荷之后&#xff0c;看有没有故障和不稳定的现象出现。 而对于压力测试&#xff0c;需要通过专业的测试设备…

【webGL入门2】点线面的绘制

用js绘制webGL的点&#xff1a; THREE.Vector3 function ( x, y, z ) {    //用THREE声明的变量都是全局变量。this.x x || 0;this.y y || 0;this.z z || 0;}; 注意&#xff1a;“||”&#xff08;或&#xff09;运算符&#xff0c;就是当xnull或者undefine时&#xff…

docker --- mysql的部署

MySQL部署 [1]查询本地镜像中是否含有 centos/mysql-57-centos7(我们用到的镜像) docker images[2] 拉取镜像 docker pull centos/mysql-57-centos7注: centos/mysql-57-centos7 是我们用到的镜像 [3] 创建容器 docker run -id --nametensquare_mysql -p 33306:3306 -e M…

Java中的排序

Java中的排序 排序方法的选择 1.若n较小(如n≤50)&#xff0c;可采用直接插入或直接选择排序。当记录规模较小时&#xff0c;直接插入排序较好&#xff1b;否则因为直接选择移动的记录数少于直接插入&#xff0c;应选直接选择排序为宜。 2.若文件初始状态基本有序(指正序)&a…

Codeforces Round #493 (Div. 2) C. Convert to Ones 乱搞_构造_好题

题意&#xff1a; 给你一个长度为 nnn 的 010101串 &#xff0c;你有两种操作&#xff1a; 1.将一个子串翻转&#xff0c;花费 XXX 2.将一个子串中的0变成1&#xff0c;1变成0&#xff0c;花费 YYY 求你将这个01串变成全是1的串的最少花费。 首先&#xff0c;我们可以将串按照0…

[T-ARA][그녀를 보면][看着那个女人的话]

歌词来源&#xff1a;http://music.163.com/#/song?id29343995 作曲 : 코난 [作曲 : Ko-nan] 作词 : 코난/로코 [作词 : Ko-nan-/lo-Ko] baby i hate you [baby i hate you] but i love you [but i love you] cant live without you [cant live without you] baby i hate you …

node --- 连接mysql(docker环境) Sequelize库

mysql 数据库 [1] 首先配置 docker 环境 采用 docker-compose 方法 源码: /test-mysql/docker-compose.yml version: 3.1 services:mysql:image: mysqlcommand: --default-authentication-pluginmysql_native_passwordrestart: alwaysenvironment:MYSQL_ROOT_PASSWORD: examp…

Java-接口练习

Java-接口练习 编写2个接口&#xff1a;InterfaceA和InterfaceB&#xff1b;在接口InterfaceA中有个方法voidprintCapitalLetter()&#xff1b;在接口InterfaceB中有个方法void printLowercaseLetter()&#xff1b;然 后写一个类Print实现接口InterfaceA和InterfaceB&#xff0…

类模板与运算符重载(一个简单的例子)

类模板与运算符重载&#xff08;一个简单的例子&#xff09; 标签&#xff08;空格分隔&#xff09;&#xff1a; C 算法竞赛 下面是一段简单的代码&#xff0c;表示我们建立了一个类模板Vector&#xff0c;可以看做是对STL中vector的简单实现。 为了让这个Vector支持通过下标…

Java 试题一

Java 试题一 1、GC是什么? 为什么要有GC 答&#xff1a;GC是垃圾收集的意思&#xff08;Gabage Collection&#xff09;,内存处理是编程人员容易出现问题的地方&#xff0c; 忘记或者错误的内存回收会导致程序或系统的不稳定甚至崩溃&#xff0c;Java提供的GC功能可以自动 …