Day5-课堂笔记-Django5

1.解决使用系统自带登录功能时,出现403错误的方法,注释如下代码

djg3->settings->MIDDLEWSRE:

MIDDLEWARE = [
    'django.middleware.security.SecurityMiddleware',
    'django.contrib.sessions.middleware.SessionMiddleware',
    'django.middleware.common.CommonMiddleware',
    # 提交时必须注释
    # 'django.middleware.csrf.CsrfViewMiddleware',
    'django.contrib.auth.middleware.AuthenticationMiddleware',
    'django.contrib.messages.middleware.MessageMiddleware',
    'django.middleware.clickjacking.XFrameOptionsMiddleware',
]

2.用户没登录时,访问需要登录才能访问的html时,默认跳转的路径

djg3->settings->末尾添加

LOGIN_URL='/user/login/'

3.users->urls.py

from django.conf.urls import url
from django.contrib.auth.decorators import login_required

from user import views

urlpatterns=[
    # 登录
    url(r'^login/',views.login,name='login'),
    # 注册
    url(r'^register/',views.register,name='register'),
    # login_required  登录后才能使用的路由
    # 首页
    url(r'^index/',login_required(views.index),name='index'),
    # 注销
    url(r'^logout/',login_required(views.logout),name='logout'),
]

4.users->views.py

from django.contrib import auth
from django.contrib.auth.models import User
from django.http import HttpResponseRedirect, HttpResponse
from django.shortcuts import render
from django.urls import reverse

from users.forms import UserForm, LoginForm


def register(request):
    if request.method=='GET':
        return render(request,'register.html')
    if request.method=='POST':
        #校验页面中传递的参数,是否填写完整
        form = UserForm(request.POST)
        #is_valid():判断表单验证是否通过
        if form.is_valid():
            # 获取校验后的用户和密码
            username=form.cleaned_data.get('username')
            password1 = form.cleaned_data.get('password1')
            password2 = form.cleaned_data.get('password2')
            # 判断密码是否相同
            # 创建普通用户creat_user,创建超级管理员用户create_superuser
            User.objects.create_user(username=username,password=password1)
            # 实现跳转
            return HttpResponseRedirect(reverse('users:login'))
        else:
            return render(request,'register.html',{'form':form})

def login(request):
    if request.method=='GET':
        return render(request,'login.html')
    if request.method=='POST':
        #表单验证,用户名和密码是否填写,校验用户名是否注册
        form =LoginForm(request.POST)
        if form.is_valid():
            # 校验用户名和密码,判断返回的对象是否为空,如果不为空,则为user对象

            user=auth.authenticate(username=form.cleaned_data['username'],
                                   password=form.cleaned_data['password'])
            if user:
                # 用户名和密码都是正确的,则登录
                #进入登录状态,满足login_required要求
                auth.login(request,user)
                #跳转页面
                return HttpResponseRedirect(reverse('users:index'))
            else:
                # 密码不正确
                return render(request,'login.html',{'error':'密码错误'})
        else:
            return render(request,'login.html',{'form':form})


def index(request):
    if request.method=='GET':
        return render(request,'index.html')


def logout(request):
    if request.method=='GET':
        # 注销
        #取消login_required的登录状态,进入未登录状态
        auth.logout(request)
        #跳转页面
        return HttpResponseRedirect(reverse('users:login'))

5.users->forms


'''
导入规则顺序
1.新引入python自带的库
2.引入地方
3.引入自定义的
'''
from django import forms
from django.contrib.auth.models import User


class UserForm(forms.Form):
    username=forms.CharField(required=True,
                             max_length=5,
                             min_length=2,
                             error_messages={
                                 'required':'用户名必填',
                                 'max_length':'用户名不能超过7个字符',
                                 'min_length':'用户名至少两个字符'
                             })
    password1=forms.CharField(required=True,
                              min_length=6,
                              error_messages={
                                  'required':'密码必填',
                                  'min_length':'密码不能少于6位'
                              })
    password2=forms.CharField(required=True,
                              min_length=6,
                              error_messages={
                                  'required':'确认密码必填',
                                  'min_length':'确认密码不能少于6个'
                              })


    def clean(self):
        # 校验用户名是否已经注册过
        user=User.objects.filter(username=self.cleaned_data.get('username'))
        if user:
            raise forms.ValidationError({'username':'用户名已存在'})

        # 校验密码和确认密码是否相同
        if self.cleaned_data.get('password1')!=self.cleaned_data.get('password2'):
            raise forms.ValidationError({'password2':'两次密码不一致'})
        return self.cleaned_data


class LoginForm(forms.Form):
    username = forms.CharField(required=True,
                               max_length=5,
                               min_length=2,
                               error_messages={
                                   'required': '用户名必填',
                                   'max_length': '用户名不能超过7个字符',
                                   'min_length': '用户名至少两个字符'
                               })
    password = forms.CharField(required=True,
                                min_length=6,
                                error_messages={
                                    'required': '密码必填',
                                    'min_length': '密码不能少于6位'
                                })
    def clean(self):
        user = User.objects.filter(username=self.cleaned_data['username'])
        if not user:
            raise forms.ValidationError({'username': '用户名不存在,请注册'})
        return self.cleaned_data

6.templates web页面

1)base.html 父模板

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>
        {% block title %}
        {% endblock %}
    </title>
</head>
    {% block extCss %}
    {% endblock %}

    {% block extJs %}
    {% endblock %}
<body>
    {% block content %}
    {% endblock %}
</body>
</html>

2)base_main.html 设置js

{% extends 'base.html' %}

{% block extJs %}
    <script src="http://ajax.googleapis.com/ajax/libs/jquery/1.3.2/jquery.min.js"type="text/javascript"></script>
{% endblock %}

3)login 登录页面

{% extends 'base_main.html' %}

{% block title %}
登录
{% endblock %}

{% block content %}

    <form action="" method="post">
        {{form.errors.username}}
        <p>姓名:<input type="text" name="username"></p>
        {{form.errors.password}}
        <p>密码:<input type="password" name="password"></p>
        <input type="submit" value="登录">

    </form>
{% endblock %}

4)register.html 注册页面

{% extends 'base_main.html' %}

{% block title %}
登录
{% endblock %}

{% block content %}

    <form action="" method="post">
        {{form.errors.username}}
        <p>姓名:<input type="text" name="username"></p>
        {{form.errors.password}}
        <p>密码:<input type="password" name="password"></p>
        <input type="submit" value="登录">

    </form>
{% endblock %}

5)index.html 首页

{% extends 'base_main.html' %}
{% block title %}
    首页
{% endblock %}
{% block content %}
    <p>我是首页,需要登录才能访问</p>
    <p><a href="{% url 'users:logout' %}">注销</a></p>
{% endblock %}
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 201,552评论 5 474
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 84,666评论 2 377
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 148,519评论 0 334
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,180评论 1 272
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,205评论 5 363
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,344评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,781评论 3 393
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,449评论 0 256
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,635评论 1 295
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,467评论 2 317
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,515评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,217评论 3 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,775评论 3 303
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,851评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,084评论 1 258
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 42,637评论 2 348
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,204评论 2 341

推荐阅读更多精彩内容

  • Android 自定义View的各种姿势1 Activity的显示之ViewRootImpl详解 Activity...
    passiontim阅读 171,321评论 25 707
  • 用两张图告诉你,为什么你的 App 会卡顿? - Android - 掘金 Cover 有什么料? 从这篇文章中你...
    hw1212阅读 12,676评论 2 59
  • 前言 最近分页功能使用的比较多,所以从网上下载个jquery分页插件来使用,之前用的都挺好的,直到昨天出现了逻辑问...
    scarecrowlxb阅读 498评论 0 2
  • 《干法》学习感悟 多欣赏别人的优点,少一分指责,要知道自身也有不足,与其眼睛盯着别人的优点,羡慕嫉妒,...
    魏万松阅读 196评论 0 0
  • Assert 断言 具体的 API 参见 junit4 javadoc static void assertArr...
    专职跑龙套阅读 574评论 1 4