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. 自己封装的tools.js文件

    /* * 生成指定范围的随机整数 * @param lower 下限 * @param upper 上限 * @return 返回指定范围的随机整数,上/下限值均可取 */ function rand ...

  2. SAP HTLM Control

    HTML 事件 效果 代码 *&---------------------------------------------------------------------* *& Re ...

  3. 基于bat脚本的前端发布流程的优化

    背景介绍 前面在基于bat脚本的前端发布流程设计与实现中,我已经介绍了设计与实现,这一篇主要是针对其的一个优化折腾(分两步走,第一步先搞出来,第二步再想着怎么去优化它),我主要做了以下几件事. &qu ...

  4. 【机器学习】K-means聚类分析

    前言 聚类问题是无监督学习的问题,算法思想就是物以类聚,人以群分,聚类算法感知样本间的相似度,进行类别归纳,对新输入进行输出预测,输出变量取有限个离散值.本次我们使用两种方法对鸢尾花数据进行聚类. 无 ...

  5. windows server2012R2 上 .net core IIS 部署--应用程序池 自动停止

    在windows server2016安装部署.NET CORE时,只需要将.net core应用程序池设置无托管,然后对应你项目的版本安装一个dotnet-hosting-2.2.6-win.exe ...

  6. 没有Kubernetes怎么玩Dapr?

    Dapr 被设计成一个面向开发者的企业级微服务编程平台,它独立于具体的技术平台,可以运行在"任何地方".Dapr本身并不提供"基础设施(infrastructure)&q ...

  7. Template -「网络流 & 二分图」

    EK. 很少用到,知道思想即可. 懒得写封装的屑. queue<int> q; int Cap[MAXN][MAXN], Flow[MAXN][MAXN], Aug[MAXN], fa[M ...

  8. 市面上的工业ERP系统如何区别?存在什么样的不同?

    工业发展当中所要涉及到的管理是繁琐而复杂的,在ERP系统的拓展开发中,市面上出现了很多的工业ERP系统来让企业选择.这是近年来非常受欢迎的一种管理手段,依靠计算机系统的强大功能,来实现数据化的管理,企 ...

  9. 使用OnPush和immutable.js来提升angular的性能

    angular里面变化检测是非常频繁的发生的,如果你像下面这样写代码 <div> {{hello()}} </div> 则每次变化检测都会执行hello函数,如果hello函数 ...

  10. MYSQL(基本篇)——一篇文章带你走进MYSQL的奇妙世界

    MYSQL(基本篇)--一篇文章带你走进MYSQL的奇妙世界 MYSQL算是我们程序员必不可少的一份求职工具了 无论在什么岗位,我们都可以看到应聘要求上所书写的"精通MYSQL等数据库及优化 ...