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. Vscode标题栏出现【不受支持】提示的完美解决方案

    安装Fix VSCode Checksums code --install-extension lehni.vscode-fix-checksums 打开命令面板,快捷键 Ctrl + Shift + ...

  2. Obsidian基础教程

    Obsidian基础教程 相关链接 2021年新教程 - Obsidian中文教程 - Obsidian Publish 软通达 基础设置篇 1. 开启实时预览 开启实时预览模式,所见即所得 打开设置 ...

  3. oracle备份数据库数据及导入数据库

    1.oracle数据库备份和导入 bat 脚本 scott oracle数据库用户名称 123456 数据库scott用户下的密码 192.168.124.8 本电脑IP orcl 为oracle库 ...

  4. Codeforces Round #804 (Div. 2)

    题目链接 A  The Third Three Number Problem 题意 给你一个n,让你求满足的a,b,c. 如果不存在则输出-1. 思路 显然任意a,b,c是不可能得到奇数. 只考虑偶数 ...

  5. java.Scanner 拓展用法

    package study5ran2yl.study; import java.util.Scanner; public class demo11 { public static void main( ...

  6. Java 范例 - 定时任务

    前言 JDK 有两种定时任务的实现,一种是单线程循环判断,另一种则是线程池. 定时器 java.util 包下有 Timer 类可用来实现定时任务,下面是一个简单的例子: Date date = ne ...

  7. APISpace 分钟级降水预报API接口 免费好用

    各种不同类型的降水对国民经济和国防建设会产生不同的影响.无论农业生产.航空.航海.交通运输.水利建设.防涝防旱等都需要以及准确的降水预报.   分钟级降水预报API,支持国内任一经纬度的预报数据,实时 ...

  8. 一些JS库汇总

    作者:wlove 链接:https://www.zhihu.com/question/429436558/answer/2348777302 来源:知乎 著作权归作者所有.商业转载请联系作者获得授权, ...

  9. Java语言的跨平台性

    2.1 Java虚拟机 -- JVM JVM:Java虚拟机,简称JVM,是运行所有java程序的假想计算机,是java程序的运行环境,是java最具吸引力的特性之一,我们编写的java代码都运行在J ...

  10. 微信公众号授权登录后报redirect_uri参数错误的问题

      在进行微信公众号二次开发的时候,需要通过授权码模式来进行微信授权.比如,在进行登录的时候,用户点击了登录按钮,然后弹出一个授权框,用户点击同意后,就可以获取用户的OpenId等信息了.这篇文章主要 ...