django_day03

Django的view(视图)

  1. CBV和FBV

    1. FBV:function based view 基于函数的视图

    2. CBV:class based view 基于类的视图

      from django.views import View
      
      class  Xxx():
      def get(self,request):
      #专门处理get请求
      return response
      def post(self,request):
      #专门处理post请求
      return response
      url(r'xx/',Xxx.as_view())
      class PublisherAdd(View):
      
          def get(self,request):
      print("get请求被执行")
      #处理get请求
      return render(request, 'publisher_add.html') def post(self,request):
      print("post请求被执行")
      #处理post请求
      pub_name = request.POST.get('pub_name')
      #print(pub_name)
      if not pub_name:
      # 输入为空
      return render(request, 'publisher_add.html', {'error': '不能为空!!'})
      if models.Publisher.objects.filter(name=pub_name):
      return render(request, 'publisher_add.html', {'error': '已存在!'})
      ret = models.Publisher.objects.create(name=pub_name)
      #print(ret, type(ret))
      return redirect('/publisher_list/')
      urlpatterns = [
      url(r'^publisher_add/', views.PublisherAdd.as_view()),
      ]

      as_view流程

      1. 项目运行时加载urls.py的文件 执行类as_view方法

      2. as_view()执行后 内部定义了一个view函数 并且返回

      3. 请求到来的时候,执行view函数:

        1. 实例化类--》self

        2. self.request = request

        3. 执行self.dispatch(request, *args, **kwargs)的方法

          1. 判断请求方式是否被允许

            1. 允许:

              通过反射获取请求方式对应的请求方法 ——》 handler

              获取不到 self.http_method_not_allowed ——》 handler

            2. 不允许:

              self.http_method_not_allowed ——》 handler

          2. 执行handler,返回结果

      from functools import wraps
      
      def timer(func):
      @wraps(func)#不加的话获取的方法一直时inner wraps原理
      def inner(request, *args, **kwargs): start = time.time()
      ret = func(request, *args, **kwargs)
      print('执行的时间是:{}'.format(time.time() - start))
      return ret return inner

      FBV

      直接加在函数上就行

      CBV加装饰器:

      需要使用一个装饰器

      from django.utils.decorators import method_decorator
      1. 加在方法上

        @method_decorator(timer)
        def get(self, request):
      2. 加在dispatch方法上

        @method_decorator(timer)
        def dispatch(self, request, *args, **kwargs):
        # 之前的操作
        ret = super().dispatch(request, *args, **kwargs) # 执行View中的dispatch方法
        # 之后的操作
        return ret3 @method_decorator(timer,name='dispatch')
        class PublisherAdd(View):
      3. 加在类上

        @method_decorator(timer,name='post')
        @method_decorator(timer,name='get')
        class PublisherAdd(View):

      request

      request.method  请求方法  GET POST
      request.GET URL上携带的参数 ?k1=v1&k2=v2 { }
      request.POST post请求提交的数据 {} 编码方式是URLencode
      request.path_info 路径信息 不包含IP和端口 也不包含参数
      request.body 请求体 bytes类型 #post请求才有 数据
      request.COOKIES cookie
      request.session session
      request.FILES 长传的文件
      request.META 头的信息 小写——》大写 HTTP_ 开头 - ——》 _ request.get_full_path() 完整的路径信息 不包含IP和端口 包含参数
      request.is_ajax() 请求是否是ajax请求

      response

      from django.shortcuts import render, HttpResponse, redirect
      
      HttpResponse('字符串')  #   返回字符串
      render(request,'模板的文件名',{'k1':v1}) # 返回一个HTML页面
      redirect('地址') # 重定向 Location:‘地址’ 301 302
      from django.http.response import JsonResponse
      JsonResponse({'k1':'v1'})
      JsonResponse(data,safe=False)

      上传文件

      urls.py

      url(r'^upload/', views.Upload.as_view()),

      视图:

      class Upload(View):
      
          def get(self, request):
      return render(request, 'upload.html')
      def post(self, request):
      file = request.FILES.get('f1')
      with open(file.name, 'wb') as f:
      for i in file:
      f.write(i)
      return HttpResponse('ok')

      upload.html

      <form action="" method="post" enctype="multipart/form-data">
      {% csrf_token %} <input type="file" name="f1">
      <button>上传</button>
      </form>

django_day03的更多相关文章

随机推荐

  1. 物联网微消息队列MQTT介绍-EMQX集群搭建以及与SpringBoot整合

    项目全部代码地址:https://github.com/Tom-shushu/work-study.git (mqtt-emqt 项目) 先看我们最后实现的一个效果 1.手机端向主题 topic111 ...

  2. 【Github】 Github修改仓库的基本信息

    前言 我们通常在刚开始了解学习使用github时,一般都是测试的使用,有时我们向里面添加了一些代买,如果想要修改信息并且是删除仓库重新创建提交,可以采用下面方法修改仓库信息,名称.描述等. 修改仓库描 ...

  3. SAP Web Dynpro - 应用程序中的服务调用

    您可以使用服务调用来调用Web Dynpro组件中的现有功能模块. 要创建服务呼叫,您可以使用Web Dynpro工具中易于使用的向导. 您可以在ABAP工作台中启动该向导以创建服务调用. 步骤1-选 ...

  4. wcf .net webService和 .net webApi的联系与差异

    首先,我们需要清楚它们的概念,然后才能走好下一步. wcf是对于ASMX,.Net Remoting,Enterprise Service,WSE,MSMQ等技术的整合,它是一种重量级消息交互框架,广 ...

  5. UiPath图片操作截图的介绍和使用

    一.截图(Take Screenshot)的介绍 截取指定的UI元素屏幕截图的一种活动,输出量仅支持图像变量(image) 二.Take Screenshot在UiPath中的使用 1. 打开设计器, ...

  6. SQL语句的整理

    mysql语句的整理 1.SQL DML 和 DDL 可以把 SQL 分为两个部分:数据操作语言 (DML) 和 数据定义语言 (DDL). SQL (结构化查询语言)是用于执行查询的语法.但是 SQ ...

  7. Linux for CentOS 下的 nginx 绿色安装-超省心安装

    1.我这里是nginx-1.13.0-1.x86_64 .rpm(点击下载)版本的. 2.安装nginx的相应环境.有些环境可能不必须,但是安装了,确保以防万一,多多益善 yum install gd ...

  8. NC24622 Brownie Slicing

    NC24622 Brownie Slicing 题目 题目描述 Bessie has baked a rectangular brownie that can be thought of as an ...

  9. charles(CA证书)的app端安装

    在使用charles进行的app抓包的时候势必需要对他进行配置: 1. pc端: 第一步: http请求接收charles > proxy > proxy setting > por ...

  10. 攻防世界MISC进阶区 52-55

    52.Excaliflag 得到一张png,扔进stegsolve中查看,找到flag 53.Just-No-One 得到一个exe,运行后居然是一个安装程序,看了一下没什么问题,扔进ida pro中 ...