Django用户登录与注册——小白教程

学习django学得超级吃力,最近弄个最简单的用户登录与注册界面都是那么难,目前算是基本实现了,虽然功能特别特别简单但是做一个记录,以后学习深入了再来补充:

首先创建项目,到项目所在目录:django-admin startproject demo0414_userauth

进入项目:cd demo0414_userauth

创建相应的app:django-admin startapp account

整个项目的结构图如图所示

.

├── account

│ ├── admin.py

│ ├── admin.pyc

│ ├── apps.py

│ ├── init.py

│ ├── init.pyc

│ ├── migrations

│ │ ├── 0001_initial.py

│ │ ├── 0001_initial.pyc

│ │ ├── init.py

│ │ └── init.pyc

│ ├── models.py

│ ├── models.pyc

│ ├── tests.py

│ ├── urls.py

│ ├── urls.pyc

│ ├── views.py

│ └── views.pyc

├── demo0414_userauth

│ ├── init.py

│ ├── init.pyc

│ ├── settings.py

│ ├── settings.pyc

│ ├── urls.py

│ ├── urls.pyc

│ ├── wsgi.py

│ └── wsgi.pyc

├── manage.py

└── templates

├── register.html

├── success.html

└── userlogin.html

4 directories, 29 files

然后在setting文件的installed_app中添加app account;

创建一个templates文件夹,可以放在项目的根目录下也可以放在app的目录下。一般情况下提倡放在app的目录下。如果放下项目的根目录下需要在setting文件中TEMPLATES中设置’DIRS’: [os.path.join(BASE_DIR,’templates’)],否则不能使用模板。

另外因为这个项目存在页面跳转的问题,为了安全防止csrf攻击,一把模板中都有了相关的设置。目前我还不会用这个东西,据说在form表单中添加标签{% csrf_token %}就可以实现了,但是我没有成功。所以先不考虑这个问题,把seeting中的这个中间件’django.middleware.csrf.CsrfViewMiddleware’,注释掉

然后在model中创建相应的数据库:

class User(models.Model):
    username = models.CharField(max_length=50)
    password = models.CharField(max_length=50)
    email = models.EmailField()

view中添加相应的程序。Pdb当时用于断点调试,我很喜欢,超级喜欢。如果你不敢兴趣,直接注释即可。

#coding=utf-8
from django.shortcuts import render,render_to_response
from django import forms
from django.http import HttpResponse,HttpResponseRedirect
from django.template import RequestContext
from django.contrib import auth
from models import User
import pdb

def login(request):
    if request.method == "POST":
        uf = UserFormLogin(request.POST)
        if uf.is_valid():
            #获取表单信息
            username = uf.cleaned_data[‘username‘]
            password = uf.cleaned_data[‘password‘]
            userResult = User.objects.filter(username=username,password=password)
            #pdb.set_trace()
            if (len(userResult)>0):
                return render_to_response(‘success.html‘,{‘operation‘:"登录"})
            else:
                return  HttpResponse("该用户不存在")
    else:
        uf = UserFormLogin()
return render_to_response("userlogin.html",{‘uf‘:uf})

def register(request):
    curtime=time.strftime("%Y-%m-%d %H:%M:%S",time.localtime());

    if request.method == "POST":
        uf = UserForm(request.POST)
        if uf.is_valid():
            #获取表单信息
            username = uf.cleaned_data[‘username‘]
            #pdb.set_trace()
            #try:
            filterResult = User.objects.filter(username = username)
            if len(filterResult)>0:
                return render_to_response(‘register.html‘,{"errors":"用户名已存在"})
            else:
                password1 = uf.cleaned_data[‘password1‘]
                password2 = uf.cleaned_data[‘password2‘]
                errors = []
                if (password2 != password1):
                    errors.append("两次输入的密码不一致!")
                    return render_to_response(‘register.html‘,{‘errors‘:errors})
                    #return HttpResponse(‘两次输入的密码不一致!,请重新输入密码‘)
                password = password2
                email = uf.cleaned_data[‘email‘]
            #将表单写入数据库
                user = User.objects.create(username=username,password=password1)
                #user = User(username=username,password=password,email=email)
                user.save()
                pdb.set_trace()
            #返回注册成功页面
                return render_to_response(‘success.html‘,{‘username‘:username,‘operation‘:"注册"})
    else:
        uf = UserForm()
return render_to_response(‘register.html‘,{‘uf‘:uf})

class UserForm(forms.Form):
    username = forms.CharField(label=‘用户名‘,max_length=100)
    password1 = forms.CharField(label=‘密码‘,widget=forms.PasswordInput())
    password2 = forms.CharField(label=‘确认密码‘,widget=forms.PasswordInput())
    email = forms.EmailField(label=‘电子邮件‘)

class UserFormLogin(forms.Form):
    username = forms.CharField(label=‘用户名‘,max_length=100)
    password = forms.CharField(label=‘密码‘,widget=forms.PasswordInput())

Tempaltes文件夹下总共有3个页面:

Register.html

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
<html xmlns="http://www.w3.org/1999/xhtml" xml:lang="en" lang="en">
<head>
    <meta http-equiv="Content-Type" content="text/html; charset=UTF-8" />
    <title>用户注册</title>
</head>
  <style type="text/css">
    body{color:#efd;background:#453;padding:0 5em;margin:0}
    h1{padding:2em 1em;background:#675}
    h2{color:#bf8;border-top:1px dotted #fff;margin-top:2em}
    p{margin:1em 0}
  </style>
<body>
<h1>注册页面:</h1>
<form method = ‘post‘ enctype="multipart/form-data">
{{uf.as_p}}
{{errors}}
</br>
<input type="submit" value = "ok" />
</form>
</body>
</html>

Userlogin.html

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
<html xmlns="http://www.w3.org/1999/xhtml" xml:lang="en" lang="en">
<head>
    <meta http-equiv="Content-Type" content="text/html; charset=UTF-8" />
    <title>用户注册</title>
</head>
  <style type="text/css">
    body{color:#efd;background:#453;padding:0 5em;margin:0}
    h1{padding:2em 1em;background:#675}
    h2{color:#bf8;border-top:1px dotted #fff;margin-top:2em}
    p{margin:1em 0}
  </style>
<body>
<h1>登录页面:</h1>
<form method = ‘post‘ enctype="multipart/form-data">

{{uf.as_p}}
<input type="submit" value = "ok" />
</form>
</body>
</html>

Success.html

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
<html xmlns="http://www.w3.org/1999/xhtml" xml:lang="en" lang="en">
<head>
    <meta http-equiv="Content-Type" content="text/html; charset=UTF-8" />
    <title></title>
</head>
<body>
<form method = ‘post‘>

    <h1>恭喜,{{operation}}成功!</h1>
</form>
</body>
</html>

更新数据库:

运行服务器:

注册页面:

如果注册的用户没有注册过,则能注册成功点击OK进入success界面

登录页面:

点击OK就能进入到success页面

时间: 2024-08-27 21:22:05

Django用户登录与注册——小白教程的相关文章

Django从零搭建个人博客 | 使用allauth插件管理用户登录与注册

原文博客地址:http://www.eosones.com/ django-allauth是最受欢迎的管理用户登录与注册的第三方Django安装包,可以大大简化我们用户注册,登录及账户管理,其核心功能包括用户注册.忘记密码.登录(微信,微博等第三方登录:邮箱验证).登录后密码重置.邮箱发送密码重置链接.退出等. 安装与设置 运行CMD,打开虚拟环境 pip install django-allauth 安装好后设置Myblog / settings.py,将allauth相关APP加入到INST

使用PHP实现用户登录和注册的功能

登陆界面 login.PHP [html] view plain copy <form action="logincheck.php" method="post"> 用户名:<input type="text" name="username" /> <br /> 密码:<input type="password" name="password" 

Java入门:用户登录与注册模块1(实践项目)——分析

任务描述:用户登录与注册是大多数软件都拥有的一个模块.请编写一个控制台程序,实现用户的登录与注册功能,并且用户能够修改自己信息. [需求分析]由于本程序是一个演示程序,用户的信息我们做简化处理,仅包括:用户名.密码和EMAIL. 1.系统功能分析 分析一个系统或一个模块,我们首先需要了解系统需要实现哪些功能,通常可采用用例图来描述分析结果.对于本任务,用例图为: 对于每个用例,可以使用用例描述表来详细阐述用例内容.用户登录注册模块的三个用例描述表如下: (1)登录用例描述表 用例名称 登录 标识

【Struts2+Hibernate3+Spring3】利用SSH整合,完成打印用户表,用户登录、注册、修改密码系统

本文视图尽可能不杂糅其它技术,尽可能少写代码,完成SSH整合.以致于各位在现有网上资料越来越天花龙凤之下,清晰地了解到传说中的三大框架SSH是怎么整合的. 一.SSH的下载 首先SSH的下载就已经是一个难点.SSH三个地方同时推出各自的新技术,已经要求利用Maven完成其版本的同步.毕竟Spring的版本,决定其能整合什么版本的Struts与Hibernate.Spring3.0.5就不能整合Hibernate4.x了.因此本文选取的SSH的版本,分别为struts 2.3.20 GA.Hibe

Java习题_Chp11-14_ *(自定义异常)完成某个计费系统的用户登录和注册模块,要求如下:

*(自定义异常)完成某个计费系统的用户登录和注册模块,要求如下: 1)创建一个User 类,包括:用户登录名(username).密码(password).用户真实姓名(name).电子邮件地址(email)属性和相应的构造方法及set/get 方法. 2)创建两个自定义异常类,一个LoginException,表示登录异常.一个RegisterException,表示注册异常.自定义的两个异常,都要求有一个接受字符串类型参数的构造方法. 3)创建一个UserBiz 接口,该接口中定义两个方法:

关于django用户登录认证中的cookie和session

最近弄django的时候在用户登录这一块遇到了困难,网上的资料也都不完整或者存在缺陷. 写这篇文章的主要目的是对一些刚学django的新手朋友提供一些帮助.前提是你对django中的session和cookie已经有了一定的了解. 我最基本的设想是当用户登陆了网站后,用户访问本网站的其他网页时依旧能识别其身份. 很多教程的方法是在用户的cookie中存储用户名,这种方法当然是非常不安全的. 其实只要我们使用了django中的session,django就会自动在用户的cookie中存储 sess

PHP用户登录与注册页面

PHP用户登录模块实现 项目包含的功能脚本: login.php//登录 reg.php//注册用户 user_add.php//注册校验脚本 user_login_check.php//登录校验脚本 image.php//验证码图片生成脚本 流程: 设计数据库: 包含用户uid,用户名,密码,昵称,性别,邮箱,注册时间 sql语句如下 create table users (uid bigint(20) not null auto_increment primary key unique ke

Django实战(一)-----用户登录与注册系统4(表单)

我们前面都是手工在HTML文件中编写表单form元素,然后在views.py的视图函数中接收表单中的用户数据,再编写验证代码进行验证,最后使用ORM进行数据库的增删改查.这样费时费力,整个过程比较复杂,而且有可能写得不太恰当,数据验证也比较麻烦. 设想一下,如果我们的表单拥有几十上百个数据字段,有不同的数据特点,如果也使用手工的方式,其效率和正确性都将无法得到保障. 有鉴于此,Django在内部集成了一个表单功能,以面向对象的方式,直接使用Python代码生成HTML表单代码,专门帮助我们快速处

DJANGO用户登录验证完整代码

1,urls.py内容: from django.conf.urls import url from django.contrib import admin from myApp import views urlpatterns = [ url(r'^admin/', admin.site.urls), url(r'^login/$', views.login), url(r'^index/$', views.index), ] 2,views.py内容 说明: 要使用session前提是要在s