Django框架03 /视图相关

1. 请求相关

  • HTTPRequest对象

    1. HTTPRequest对象就是咱们的视图函数的参数request
    2. 当一个页面被请求时,Django就会创建一个包含本次请求原信息(请求报文中的请求行、首部信息、内容主体等)的HttpRequest对象。
    3. Django会将这个对象自动传递给响应的视图函数,一般视图函数约定俗成地使用 request 参数承接这个对象。
  • 请求相关的常用值

    path_info
    # 返回用户访问url,不包括域名 method
    # 请求中使用的HTTP方法的字符串表示,全大写表示 GET
    # 包含所有HTTP GET参数的类字典对象 POST
    # 包含所有HTTP POST参数的类字典对象 body
    b'name=python&price=123.00'
    # 请求体,byte类型 request.POST的数据就是从body里面提取到的
  • 属性

    print(request)   # <WSGIRequest: GET '/home/'>
    print(dir(request)) print(request.path) # /home/ 纯路径
    print(request.path_info) # /home/ 纯路径
    print(request.get_full_path()) # /home/?a=1&b=2 全路径(不包含ip地址和端口) print(request.META) # 请求头相关数据,是一个字典 print(request.method) # GET print(request.GET) # <QueryDict: {}> QueryDict对象存储GET相关数据 print(request.POST)
    print(request.body) # 能够拿到请求数据部分的数据(post有,get没有)

2.响应相关

  • HTTPResponse对象

    # 返回字符串
    HTTPResponse('字符串') # 返回页面
    render(request,'xx.html') # 重定向
    redirect 重定向
    # 用法:redirect(路径)/ redirect(别名)
    # 示例:redirect('/index/')
  • 重定向/301/302

    1. 301和302的区别

      • 相同点:

        • 301和302状态码都表示重定向,就是说浏览器在拿到服务器返回的这个状态码后会自动跳转到一个新的URL地址,这个地址可以从响应的Location首部中获取(用户看到的效果就是他输入的地址A瞬间变成了另一个地址B)
      • 不同点:
        • 301表示旧地址A的资源已经被永久地移除了(这个资源不可访问了),搜索引擎在抓取新内容的同时也将旧的网址交换为重定向之后的网址
        • 302表示旧地址A的资源还在(仍然可以访问),这个重定向只是临时地从旧地址A跳转到地址B,搜索引擎会抓取新的内容而保存旧的网址。
    2. 重定向原因:
      • 网站调整(如改变网页目录结构)
      • 网页被移到一个新地址
      • 网页扩展名改变(如应用需要把.php改成.Html或.shtml)
      • 这种情况下,如果不做重定向,则用户收藏夹或搜索引擎数据库中旧地址只能让访问客户得到一个404页面错误信息,访问流量白白丧失;再者某些注册了多个域名的网站,也需要通过重定向让访问这些域名的用户自动跳转到主站点
    3. 临时重定向(响应状态码:302)和永久重定向(响应状态码:301)对普通用户来说是没什么区别的,它主要面向的是搜索引擎的机器人
      • A页面临时重定向到B页面,那搜索引擎收录的就是A页面
      • A页面永久重定向到B页面,那搜索引擎收录的就是B页面

3.FBV和CBV 视图(视图函数和视图类)

3.1 类视图 CBV

  • views.py

    from django.views import View
    class LoginView(View): def dispatch(self, request, *args, **kwargs):
    print('请求来啦!!!!')
    ret = super().dispatch(request, *args, **kwargs)
    print('请求处理的逻辑已经结束啦!!!')
    return ret
    def get(self,request):
    print('get请求')
    return render(request,'login.html') def post(self,request):
    print(request.POST)
    return HttpResponse('登录成功') # 处理get/post请求直接定义get/post方法,不需要自己判断请求方法了,源码中用dispatch方法中使用了反射来处理的
  • urls.py路由写法

    url(r'^login/', views.LoginView.as_view()),

3.2 视图函数 FBV

  • views.py

    def login(request,*args,**kwargs):
    if request.method == 'GET':
    return render(request,'login.html')
    elif request.method == 'POST':
    username = request.POST.get('username')
    password = request.POST.get('password')
    if username == 'zhangsan' and password == '123':
    return render(request,'index.html')
  • urls.py路由写法

    url(r'^login/', views.login),

3.3 视图加装饰器

  • 代码示例:

    # 装饰器
    def wrapper(func):
    def inner(*args, **kwargs):
    print(11111)
    ret = func(*args, **kwargs)
    print(22222)
    return ret
    return inner # 视图函数
    @wrapper
    def index(request):
    print('index')
    return HttpResponse('indexxxxxxxxx') # 视图类
    from django.utils.decorators import method_decorator
    @method_decorator(wrapper,name='get') #方式3 class LoginView(View):
    @method_decorator(wrapper) #方式2
    def dispatch(self, request, *args, **kwargs)
    print('请求来啦!!!!') ret = super().dispatch(request, *args, **kwargs) print('请求处理的逻辑已经结束啦!!!')
    return ret
    @method_decorator(wrapper) #方式1
    def get(self,request):
    print('get请求')
    return render(request,'login.html') def post(self,request):
    print(request.POST)
    return HttpResponse('登录成功')
  • 添加装饰器的三种方式

    • 方式1:

      添加在每一个函数中
    • 方式2:

      直接添加在dispatch里面,这样每个函数都会执行
    • 方式3:

      直接添加在类上,后面的name表示只给get添加装饰器

      以这种方式如果想给多个方法加装饰器,需要写多层装饰器,因为name这个参数的值必须是个字符串,并且不能同时写两个方法
  • 注意:

    1. 添加装饰器前必须导入from django.utils.decorators import method_decorator
    2. 添加装饰器的格式必须为@method_decorator(),括号里面为装饰器的函数名
    3. 给类添加时必须声明name

Django框架03 /视图相关的更多相关文章

  1. Django框架04 /模板相关、别名/反向解析/路由分发

    Django框架04 /模板相关.别名/反向解析/路由分发 目录 Django框架04 /模板相关.别名/反向解析/路由分发 1. 语法 2. 变量/万能的点 3 . 过滤器 4. 标签Tags 5. ...

  2. django框架-DRF视图中的request和response

    1.Request 相对于django框架,DRF工程的request类则是继承自HttpRequest类,Rest framework提供了parser解释器,用来解释请求中的content_typ ...

  3. Django框架简介-视图系统

    2.3 视图系统 一个视图函数(类),简称视图,是一个简单的Python 函数(类),它接受Web请求并且返回Web响应. 响应可以是一张网页的HTML内容,一个重定向,一个404错误,一个XML文档 ...

  4. Django框架1——视图和URL配置

    三个命令 1.创建一个django项目 在cmd中:django-admin.py startproject project_name D:\python\django_site>django- ...

  5. django框架基础-视图系统-长期维护

    ##################   什么是视图?     ####################### 视图: 1,一个视图函数(类),简称视图,是一个简单的Python 函数(类),它接受W ...

  6. Django 框架之视图函数(Views)

    http请求中产生的两个核心对象: http请求: HttpRequest对象 http响应: HttpResponse对象 所在位置: django.http HttpRequest 对象的属性和方 ...

  7. [Django框架之视图层]

    [Django框架之视图层] 视图层 Django视图层, 视图就是Django项目下的views.py文件,它的内部是一系列的函数或者是类,用来专门处理客户端访问请求后处理请求并且返回相应的数据,相 ...

  8. Django框架 之 view视图

    Django框架 之 view视图 浏览目录 概述 简单的视图 HttpRequest对象 CBV和FBV 给视图加装饰器 Request对象 Response对象 JsonResponse对象 Dj ...

  9. Python的Django框架中的Cookie相关处理

    Python的Django框架中的Cookie相关处理 浏览器的开发人员在非常早的时候就已经意识到. HTTP's 的无状态会对Web开发人员带来非常大的问题,于是(cookies)应运而生. coo ...

随机推荐

  1. MATLAB作图之二

    "平滑"二维图像可以通过对图像进行插值实现.那么对于一条有大量"毛刺"的曲线,是不是也可以通过插值来平滑呢?答案是肯定的. "平滑"前 x ...

  2. [ARC060D] 最良表現

    题目   点这里看题目. 分析   由于 KMP 的失配数组有着天然的找循环节的功能,因此我们不难想到对原串进行两次 KMP ,一正一反.   可以发现如下的规律:   1. 原串无循环节,这个时候 ...

  3. (一)HttpClient Get请求

    原文链接:https://blog.csdn.net/justry_deng/article/details/81042379 HttpClient的主要功能: 实现了所有 HTTP 的方法(GET. ...

  4. MySQL——事务(Transaction)详解

    原文:https://blog.csdn.net/w_linux/article/details/79666086

  5. 《ElasticSearch入门》一篇管够,持续更新

    一.顾名思义: Elastic:灵活的:Search:搜索引擎 二.官方简介: Elasticsearch是一个基于Lucene的搜索服务器.它提供了一个分布式多用户能力的全文搜索引擎,基于RESTf ...

  6. 《Java并发编程的艺术》第5章 Java中的锁 ——学习笔记

    参考https://www.cnblogs.com/lilinzhiyu/p/8125195.html 5.1 Lock接口 锁是用来控制多个线程访问共享资源的方式. 一般来说一个锁可以防止多个线程同 ...

  7. deepin文件用途

    Bin:二进制文件, 存放二进制文件Dev:存放外接设备,其中外接设备不能被直接使用需要挂载(启动设备)Etc:存放配置文件Home:家目录,出了root用户外的其他用户类似于Windows中的use ...

  8. 基于 abp vNext 和 .NET Core 开发博客项目 - 终结篇之发布项目

    系列文章 基于 abp vNext 和 .NET Core 开发博客项目 - 使用 abp cli 搭建项目 基于 abp vNext 和 .NET Core 开发博客项目 - 给项目瘦身,让它跑起来 ...

  9. Consul入门初识

    Consul Consul是一个支持多数据中心分布式高可用的服务发现和配置共享的服务软件,由HashiCrop公司用Go语言开发,基于Mozilla Public License 2.0的协议进行开源 ...

  10. java scoket Blocking 阻塞IO socket通信四

    记住NIO在jdk1.7版本之前是同步非阻塞的,以前的inputsream是同步阻塞的,上面学习完成了Buffer现在我们来学习channel channel书双向的,以前阻塞的io的inputstr ...