Django框架03 /视图相关

1. 请求相关

  • HTTPRequest对象

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

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

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

2.响应相关

  • HTTPResponse对象

    1. # 返回字符串
    2. HTTPResponse('字符串')
    3. # 返回页面
    4. render(request,'xx.html')
    5. # 重定向
    6. redirect 重定向
    7. # 用法:redirect(路径)/ redirect(别名)
    8. # 示例: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

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

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

3.2 视图函数 FBV

  • views.py

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

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

3.3 视图加装饰器

  • 代码示例:

    1. # 装饰器
    2. def wrapper(func):
    3. def inner(*args, **kwargs):
    4. print(11111)
    5. ret = func(*args, **kwargs)
    6. print(22222)
    7. return ret
    8. return inner
    9. # 视图函数
    10. @wrapper
    11. def index(request):
    12. print('index')
    13. return HttpResponse('indexxxxxxxxx')
    14. # 视图类
    15. from django.utils.decorators import method_decorator
    16. @method_decorator(wrapper,name='get') #方式3
    17. class LoginView(View):
    18. @method_decorator(wrapper) #方式2
    19. def dispatch(self, request, *args, **kwargs)
    20. print('请求来啦!!!!')
    21. ret = super().dispatch(request, *args, **kwargs)
    22. print('请求处理的逻辑已经结束啦!!!')
    23. return ret
    24. @method_decorator(wrapper) #方式1
    25. def get(self,request):
    26. print('get请求')
    27. return render(request,'login.html')
    28. def post(self,request):
    29. print(request.POST)
    30. 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. Nirvana【思维+暴力优化】

    Nirvana 题目链接(点击) Kurt reaches nirvana when he finds the product of all the digits of some positive i ...

  2. 数据处理一条龙!这15个Python库不可不知

    如果你是一名数据科学家或数据分析师,或者只是对这一行业感兴趣,那下文中这些广受欢迎且非常实用的Python库你一定得知道. 从数据收集.清理转化,到数据可视化.图像识别和网页相关,这15个Python ...

  3. 【漏洞复现】Fastjson <=1.2.47远程命令执行

      0x01 漏洞概述 漏洞描述 Fastjson是一款开源JSON解析库,它可以解析JSON格式的字符串,支持将Java Bean序列化为JSON字符串,也可以从JSON字符串反序列化到JavaBe ...

  4. controlfile的情景恢复

    控制文件测试 百度百科:控制文件(Control File)是Oracle的物理文件之一,它记录了数据库的名字.数据文件的位置等信息.控制文件的重要性在于,一旦控制文件损坏,数据库将会宕机.如果没有数 ...

  5. ZWave对COMAND CLASS的处理流程

    文章主题  在开发一个 ZWave Device 的过程中,对 COMAND CLASS(单词太长了,后面就简写为 CC 啦) 的处理是最基本.最重要的工作.这篇文章以最最简单的 CC:COMMNAD ...

  6. Numpy中的广播机制,数组的广播机制(Broadcasting)

    这篇文章把numpy中的广播机制讲的十分透彻: https://jakevdp.github.io/PythonDataScienceHandbook/02.05-computation-on-arr ...

  7. android中获取其他应用的SharedPreferences

    在android中获取其他应用的SharedPreferences,需要其他应用设置的Mode为MODE_WORLD_READABLE或者MODE_WORLD_WRITABLE两种模式.要获取其他应用 ...

  8. VS Code WebApi系列——3、发布

    上两篇已经实现了WebApi及基于jwt的Token设置,那么功能做完了,该发布WebApi了.为什么要对发布进行一下说明呢,因为是基于vscode和.netcore的发布,所以可能会遇到莫名奇妙的问 ...

  9. vue 深度拷贝 除去空的参数

    // 去除数组里面为空的属性及子数组 export function deepCopy (source) { var result = [] //var result = {} for (var ke ...

  10. 《Elasticsearch 权威指南》阅读笔记

    书籍地址 https://www.elastic.co/guide/cn/elasticsearch/guide/current/languages.html