Django1.11 用户注册登录(1)

添加注册登录这个功能,我们就要用到models ,views ,url ,templates。


templates 模板

我们先写两个 html 页面。

register

"{% url 'register' %}" method="post" accept-charset="utf-8"enctype="multipart/form-data" > {% csrf_token %} type="text" name="username"id="username" placeholder="请输入手机号" > type="password" name="password" id="password" placeholder="请输入6-12位密码" > type="submit" class="submit" value="立即注册">

login

"{% url 'login' %}" method="post" accept-charset="utf-8" enctype="multipart/form-data"> {% csrf_token %} type="text" name="username" id="username" placeholder="手机号码" > type="password" name="password" id="password" placeholder="登陆密码" value="" > type="submit" value="立即登录">

将以上表单贴入html
action=”{% url ‘login’ %}” 以及action = {% url ‘register’ %},关联的是 urls.py 文件中 url()的name属性的全局作用。


models.py 创建数据库表格

from django.db import models

# Create your models here.
class User(models.Model):
    username = models.CharField(max_length=21)
    password= models.CharField(max_length=21)

创建一个User表格,再数据库里的表格名 为 APP名 + User。如app 名为 taobao , 表格名为 taobao_user

创建一个表单的样式

在app 下创建一个 forms.py文件

from django import forms

class UserForm(forms.Form):
    username = forms.CharField(max_length=30)
    password = forms.CharField(max_length=50)

views 视图

from taobao.models import User
# taobao 是 app名
from .forms import UserForm

#注册
@csrf_exempt
def register_view(req):
    context = {}
    if req.method == 'POST':
        form = UserForm(req.POST)
        if form.is_valid():
            #获得表单数据
            username = form.cleaned_data['username']
            password = form.cleaned_data['password']

            #添加到数据库(还可以加一些字段的处理)
            User.objects.create(username=username, password=password)
            #添加到session
            req.session['username'] = username
            #重定向到首页
            return redirect('/')
    else:
        context = {'isLogin':False}
    #将req 、页面 、以及context{}(要传入html文件中的内容包含在字典里)返回
    return  render(req,'register.html',context)

#登陆
@csrf_exempt
def login_view(req):
    context = {}
    if req.method == 'POST':
        form = UserForm(req.POST)
        if form.is_valid():
            #获取表单用户密码
            username = form.cleaned_data['username']
            password = form.cleaned_data['password']
            #获取的表单数据与数据库进行比较
            user = User.objects.filter(username = username,password = password)
            if user:
                #比较成功,跳转index
                req.session['username'] = username
                return redirect('/')
            else:
                #比较失败,还在login
                context = {'isLogin': False,'pawd':False}
                return render(req, 'login.html', context)
    else:
        context = {'isLogin': False,'pswd':True}
    return render(req, 'login.html', context)

#登出    
def logout_view(req):
    #清理cookie里保存username
    req.session.flush()
    return redirect('/')

urls.py

直接上代码,name 中对应templates 中的 表单中的action

    url(r'^login$', views.login_view,name='login'),
    url(r'^logout', views.logout_view),
    url(r'^register$', views.register_view,name='register'),

你可能感兴趣的:(Django1.11,python3)