Django 框架基础9:视图(V)类视图、中间件

1、类视图

类视图是采用面向对象的思路

  • 定义类视图
    ① 继承自django.views的View。
    ② 不同的请求方式有不同的业务逻辑.类视图的方法就直接采用http请求名字作为函数名,如,get,post,put,patch,delete,head,options,trace等。
    ③ 类视图的第一个参数固定为self,第二个参数必须是请求实例对象request。类视图的方法,必须有返回值,返回值是HttpResponse及其子类。
  • 类视图的url引导
    ① url第一个参数是正则,login/。
    ② 第二个参数是个视图函数名 LoginView.as_view()

定义类视图

from django.views import View
class LoginView(View):

    def get(self, request):
        return HttpResponse('get')

    def post(self, request):
        return  HttpResponse('post')

    def put(self, request):
        return HttpResponse('put')

    def OOOO(self, request):  # 函数名不是http协议
        return HttpResponse('OOOO')

 类视图定义路由

from django.urls import re_path
from book.views import login, index, detail, set_cookie, get_cookie,set_session,get_session,LoginView,CenterView

app_name = 'book'
urlpatterns = [
    re_path('^get_session/$', get_session, name='get_cookie'),
    re_path('^login/$', LoginView.as_view()),
    re_path('^center/$', CenterView.as_view()),

]

 类视图的多继承

"""
业务需求:
个人中心页面 -- 必须登录才能显示
    GET 展示个人中心
    POST 实现个人中心信息的修改
"""
from django.contrib.auth.mixins import LoginRequiredMixin
class CenterView(LoginRequiredMixin, View):
    """
    两个父类按MRO的顺序,也可以理解为业务流程
    登录个人中心首先需要验证是否登录,django的LoginRequireMixin封装好了验证方法
    如果检测到没有登录,会自动跳转到 http://127.0.0.1:8000/accounts/login/?next=/center/
    """

    def get(self, request):
        return HttpResponse('个人中心展示')

    def post(self, request):
        return HttpResponse('个人信息修改')
from django.urls import re_path
from book.views import login, index, detail, set_cookie, get_cookie,set_session,get_session,LoginView,CenterView

app_name = 'book'
urlpatterns = [
    re_path('^get_session/$', get_session, name='get_cookie'),
    re_path('^login/$', LoginView.as_view()),
    re_path('^center/$', CenterView.as_view()),

]

 2、中间件

Django中的中间件是一个轻量级底层的插件系统,可以介入 Django的请求和响应处理过程,修改Django的输入或输出。中间件的设计为开发者提供了一种无侵入式的开发方式,增强了 Django框架的健壮性。
我们可以使用中间件,在 Django处理视图的不同阶段对输入或输出进行干预
中间件文档:https://docs.djangoproject.com/en/3.2/topics/http/middleware/

中间件的定义方法:

  • 定义一个中间件工厂函数,然后返回一个可以被调用的中间件。
  • 中间件工厂函数需要接收一个可以调用的 get_response对象
  • 返回的中间件也是一个可以被用的对象,并且像视图一样需要接收一个 request对象参数,返回一个 response对象。

定义

def simple_middleware(get_response):
    def middleware(request):
        print('before')
        response = get_response(request)
        print('after')
        return response

    return middleware

注册

执行结果:http://localhost:8000/set_session/?username=yuan&pass=123456

多个中间件的执行顺序:

请求前:按注册顺序执行
请求后/响应后:与注册顺序相反

def simple_middleware(get_response):
    def middleware(request):
        print('before1111')
        response = get_response(request)
        print('after1111')
        return response

    return middleware


def simple_middleware2(get_response):
    def middleware(request):
        print('before2222')
        response = get_response(request)
        print('after22222')
        return response

    return middleware
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',
    'book.middleware.simple_middleware',
    'book.middleware.simple_middleware2',
]

中间件初始化

def simple_middleware(get_response):
    print('init_1111')  # 从程序运行后只执行一次
    def middleware(request):
        print('before1111')
        response = get_response(request)
        print('after1111')
        return response

    return middleware

 中间件实例说明

# -*- encoding: utf-8 -*-
"""
中间件的作用:每次请求和响应的时候都会调用
中间件的定义:嵌套视图函数
中间件的注册:在settings.py的MIDDLEWARE=[]列表中添加 'book.middleware.simple_middleware',
中间件的使用举例:可以判断每次请求中是否携带了cookie的某些信息
"""
from django.http import HttpResponse
def simple_middleware(get_response):
    # 这里是中间件第一次调用执行的地方,程序启动,首次发送请求会执行一次,以后的请求不会执行
    print('init___middleware')

    def middleware(request):
        # 这里是请求前
        print('before request')
        username = request.COOKIES.get('username')
        if username is None:
            print('usename is None!')
            # return HttpResponse('亲,你没有登录啊!')
        else:
            print(username)

        response = get_response(request)

        # 这里是响应后/请求后
        print('after response/request')

        return response

    return middleware

 

posted @ 2023-02-26 11:42  周柏  阅读(100)  评论(0编辑  收藏  举报