首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

03.Django基础三之视图函数

name属性,并且会被传进来的这个属性值给覆盖掉 ] 三 使用Mixin(了解)   我觉得要理解django的class-based-view(以下简称cbv),首先要明白django引入cbv的目的是什么...cbv的实现原理通过看django的源码就很容易明白,大体就是由url路由到这个cbv之后,通过cbv内部的dispatch方法进行分发,将get请求分发给cbv.get方法处理,将post请求分发给cbv.post...Django会将这个对象自动传递给响应的视图函数,一般视图函数约定俗成地使用 request 参数承接这个对象。...默认当上传文件小于2.5M时,django会将上传文件的全部内容读进内存。从内存读取一次,写磁盘一次。...return redirect('some-view-name', foo='bar') 传递要重定向到的一个具体的网址 def my_view(request): ...

5K30

Django中请求的生命周期

Django的请求生命周期是指当用户在浏览器上输入url到用户看到网页的这个时间段内,Django后台所发生的事情 而Django的生命周期内到底发生了什么呢?? 1....视图函数根据客户端的请求查询相应的数据后.如果同时有多个客户端同时发送不同的url到服务端请求数据 服务端查询到数据后,怎么知道要把哪些数据返回给哪个客户端呢??...type="submit"> form> 启动项目,在浏览器中输入http://127.0.0.1:8000/cbv/,回车,得到的网页如下: ?...Django从数据库中查询处理完用户想要的数据,将结果返回给用户....从Django中返回的响应内容包含响应头和响应体 在Django中,有的时候一个视图函数,执行完成后会使用HttpResponse来返回一个字符串给客户端.

2.7K100
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    Django之视图层与模板层

    /form-data" 如果form表单提交数据是按照编码格式1,那么request.body中数据的格式类似于GET方法的数据格式,如 k1=v1&k2=v2,此时django会将request.body...:url(r'^login/',views.MyLogin.as_view()) 从路由的书写可以看出这里执行的是类的方法,而方法的本质还是函数所以CBV在路由匹配上的本质还是FBV。...): # 如果你想在视图函数执行之前做一些操作,你可以在你的CBV中定义dispatch方法来拦截 return super().dispatch(request,*args,**kwargs...# 具体工作原理为: # 1、在GET请求到form表单时,标签{% csrf_token%}会被渲染成一个隐藏的input标签,该标签包含了由服务端 生成的一串随机字符串,如<input type=...',{'n':n}) # 第二种,使用locals()会将当前所在名称空间中所有的名字全部传递给html页面 2.5模板的继承和导入 在实际开发中,模板文件彼此之间可能会有大量的冗余代码,为此Django

    9.2K10

    Django-DRF | 请求

    Django REST框架构建Web API。...Django网络应用开发的5项基础核心技术包括模型(Model)的设计,URL 的设计与配置,View(视图)的编写,Template(模板)的设计和Form(表单)的使用。...默认输入url的请求方式即为get,当请求方式为get时,若带有需要传递的其他参数,则会将该参数的name和value补充在url中一并提交,post方式则将数据放在内容中一并提交,不再url中显示。...在浏览器发送的request数据包的header中,可以看到这些内容,例如: 一、CBV 视图里使用类处理请求,在url中一个路径对应一个类。...,一般情况下发送数据 def post(self, *args, **kwargs): return HttpResponse('万事顺心') cbv 定义类需要继承 View

    66020

    Django的请求生命周期

    Django的请求生命周期是指当用户在浏览器上输入url到用户看到网页的这个时间段内,Django后台所发生的事情 而Django的生命周期内到底发生了什么呢?? 1....视图函数根据客户端的请求查询相应的数据后.如果同时有多个客户端同时发送不同的url到服务端请求数据 服务端查询到数据后,怎么知道要把哪些数据返回给哪个客户端呢??...: from django.views import View class CBV(View): def dispatch(self, request, *args, **kwargs):...Django从数据库中查询处理完用户想要的数据,将结果返回给用户....从Django中返回的响应内容包含响应头和响应体 在Django中,有的时候一个视图函数,执行完成后会使用HttpResponse来返回一个字符串给客户端.

    55320

    继续Django

    base view 3、    之前写的都是FBV的方式多点,下面通过一个CBV的例子来理解CBV 首先先写一个home.html文件,代码如下: django打印的日志可以看出都是的get请求: ? 当点击提交的时候:查看django的日志可以看出是post请求; ? 4、    关于CBV,django在内部是如何实现的?  ...其实当发送请求的时候,是将Request URL以及Request Method同时传递给django,先匹配url,然后去找对应的类,然后找相应的方法,也就是post或者get等,这里判断是post还是...) 从函数可以看出是dispatch先做了一个反射的功能 所以这个请求的过程是:请求--->dispatch--->get/post 将views.py中的代码更改为如下: from django.views...),这样当多个参数的就会传递到*args里,当传递字典类型的参数的时候就会传递到**kwargs 4、    name name是对URL路由关系进行命名,以后可以根据此名称生成自己想要的URL url

    2.1K70

    不会DRF?源码都分析透了确定不来看?

    官网:https://www.django-rest-framework.org/ drf安装默认安装的最新版本,如果django版本过低会自动升级到3.x版本 版本支持对应关系 示例...,这里尽量在body体里写全参数 局部修改:修改id为1的数据,修改啥写啥 删除一条数据:删除id为2的数据 CBV源码流程分析 因为DRF框架里大部分都是基于CBV(视图类)...FBV都是函数的内存地址,比如views.类.as_view()底层仍然是函数的内存地址 CBV源码执行流程 '''views.py''' from django.views import View...且看分析源码执行过程~ '''请求来了在不考虑中间件的情况下,从路由的匹配关系和视图函数来看''' 1、cbv路由写法:path('test/', views.TestView.as_view()) #...(self, request, *args, **kwargs): # request是新的drf提供的request,它是由老的django的request得到的 # 通过老

    1.3K10

    类视图 vs. 函数视图

    介绍 无论是类视图还是基于函数的视图, 最终绑定到 URL Conf 的都是函数. 为什么这么说? 函数绑定到 URL 上面很显式的证明了绑定的是函数, 这一点毋庸置疑。...调用后, 视图将请求传递给dispatch() 方法,该方法将根据请求的类型(GET, POST, PUT, etc)执行响应的方法(详情参考django/views/generic/base.py,...#2 观点 「仅使用django.views.generic.View, 不用GV」 此观点认为, View 就足够了, 并且 View 是真正的CBV, 而通用视图则不是真正的 CBV....在函数视图和通用视图中间位置. #3 观点 「除非必要, 否则避免适用视图」 一般建议是从功能视图开始,这样更容易阅读和理解。并且在你需要的地方使用 CBV。一般在哪里需要用到 CBV?...任务需要在多个视图中重用代码的地方, 这个场景下 CBV 是最好的选择。 我建议是选择第三种,正如那句话『从需求场景选择最佳的实现』 最佳的做法取决你自己, .

    2.5K10

    CSRF 跨站请求伪造

    使用验证 Referer 值的方法,就是把安全性都依赖于第三方(即浏览器)来保障,从理论上来讲,这样并不安全。...Django 中处理CSRF csrf是针对与post请求的才会做验证 几种处理方式 csrf_token 用于form表单中,作用是跨站请求伪造保护。...注释掉中间件'django.middleware.csrf.CsrfViewMiddleware'【不推荐】 Form表单中 form action="" method="post"> {%...这里使用装饰器就可以解决~ 两个装饰器可用: csrf_protect: 需要验证 csrf_exempt:不需要验证 装饰器的使用方法按照FBV或者CBV装饰器的使用方法即可 导入:from django.views.decorators.csrf...装饰器示例,CBV装饰器有三种用法分别局部验证都可以使用 # 方式一,加在方法上验证,可以使用 '''局部验证,全局的csrf禁用''' from django.utils.decorators import

    1.1K20

    Django-中间件-csrf扩展请求伪造拦截中间件-Django Auth模块使用-效仿 django 中间件配置实现功能插拔式效果-09

    目录 昨日补充:将自己写的 login_auth 装饰装在 CBV 上 django 中间件 django 请求生命周期 ***** 默认中间件及其大概方法组成 中间件的执行顺序 自定义中间件探究不同操作对中间件执行顺序的影响...只要是涉及到全局的校验几乎都可以在中间件中完成,第一时间该想到的也是中间件 django 的中间件是设计比较完善的,逻辑最清晰,最简单(flask的中间件不如它) 讲完这个中间件就知道为什么我们前面每次提交...(下次就可以直接在缓存数据库中拿到数据了) 具体原理等后期涉及到展开来讲, 先知道这个概念就行 默认中间件及其大概方法组成 django 默认有七个中间件 django 支持用户自定义自己的中间件...不同浏览器绝对不一样 post请求提交数据通过 csrf 校验 form 表单 form 表单发送 post 请求的时候,需要你做的是写一段代码 {% csrf_token %} 即可,不需要注释 csrf...后台管理只有超级用户才能进入 用了 Auth 模块的方法 ,就最好都用 Auth 模块的方法 修改密码必须调用 .save() 保存,否则无效 使用 django 自带的 auth 表做登录功能 涉及到的

    1.4K50

    Django之URL(路由系统)用法

    view: 当正则表达式匹配到某个条目时,自动将封装的HttpRequest对象作为第一个参数,正则表达式“捕获”到的值作为第二个参数,传递给该条目指定的视图。...如果是简单捕获,那么捕获值将作 为一个位置参数进行传递,如果是命名捕获,那么将作为关键字参数进行传递。 kwargs: 任意数量的关键字参数可以作为一个字典传递给目标视图。...,将url以参数的形式传递到函数,可以不按顺序排列 urlpatterns = [ url(r'^user_list/(?...{"v1":"\d+"} 然后将此参数传递到views里对应的函数,可以不按照顺序 def user_list(request,v2,v1): return HttpResponse(v1+v2) 参数...项目中,我们经常会遇到要在视图中返回一个重定向到具体URL的响应,或者要将具体的URL地址嵌入到HTML页面中(如:a标签的href属性等)的情况。

    1.8K10

    Django 视图 之FBV与CBV

    Django 视图之FBV 与 CBV FBV(function base views) 基于函数的视图,就是在视图里使用函数处理请求 CBV(class base views) 基于类的视图,就是在视图里使用类处理请求...) ,as_view 方法是基于类的外部接口, 他返回一个视图函数,调用后请求会传递给 dispatch 方法,dispatch 方法再根据不同请求来处理不同的方法。...'views.py''' from django.shortcuts import render,HttpResponse from django.views import View class Func2...这样看起来CBV基于类的本质也是基于函数,在满足func2的情况下触发视图函数,源码展示如下: @classonlymethod # 绑定给类的 def as_view(cls, **initkwargs...from dispatch update_wrapper(view, cls.dispatch, assigned=()) return view dispatch方法可以从继承的父类中查找

    35810
    领券