网页版传奇网站,网站建设之织梦后台熊掌号主页,吉林seo管理平台,dw asp access 网站开发优点一. 概念 FBV#xff08;function base views#xff09; 顾名思义基于函数的视图类
CBV#xff08;class base views#xff09;基于类的视图类
至于区别呢? 我觉得只是写法上的不一样, 实现的结果都是一样的, 我比较喜欢用CBV模式, 因为在Django中内部帮我做了请求方式…一. 概念 FBVfunction base views 顾名思义基于函数的视图类
CBVclass base views基于类的视图类
至于区别呢? 我觉得只是写法上的不一样, 实现的结果都是一样的, 我比较喜欢用CBV模式, 因为在Django中内部帮我做了请求方式的判断, 无需用户实现方法判断逻辑, 来看看代码的区别吧
二. 实现代码1.FBV fbv就是在url中一个路径对应一个函数. 在工程下的url中写如下代码
from api import viewsurlpatterns [path(admin/, admin.site.urls),path(, include(api.urls)),url(r^test/, views.test_fbv)
] 然后在api的views中写如下测试函数:
def test_fbv(request):if(request.method POST):return HttpResponse(post)if (request.method PUT):return HttpResponse(put)if (request.method GET):return HttpResponse(get)
然后运行整个整个工程, 命令行输入python manage.py runserver
因为我的是linux系统, 就选用restclient这个插件进行api的测试
点完send后再看看 返回什么数据, 在response中可以 看到get
可以看到和我们想象的结果一样, 那我们在试试其他的请求方式, 比如put, post等 和我们代码写的一样, 这里我就不截图了
基于方法的视图
REST framework 也允许使用基于函数的视图。它提供了一套简单的装饰器来包装你的函数视图以确保它们接收 Request而不是 Django HttpRequest实例并允许它们返回 Response而不是 Django HttpResponse并允许你配置该请求的处理方式。
api_view()
用法api_view(http_method_names[GET])
api_view 是一个装饰器用 http_method_names 来设置视图允许响应的 HTTP 方法列表举个例子编写一个简单的视图手动返回一些数据。
from rest_framework.decorators import api_viewapi_view()
def hello_world(request):return Response({message: Hello, world!})默认情况下只有 GET 方法会被接受。其他方法将以 405 Method Not Allowed 进行响应。要使用其他方法请指定视图允许的方法如下所示
api_view([GET, POST])
def hello_world(request):if request.method POST:return Response({message: Got some data!, data: request.data})return Response({message: Hello, world!})API 策略装饰器 (policy decorators)
为了覆盖默认设置REST framework 提供了一系列可以添加到视图中的附加装饰器。这些必须在 api_view 装饰器之后下方。
例如要创建一个使用 throttle 来确保它每天只能由特定用户调用一次的视图请使用 throttle_classes 装饰器传递一个 throttle 类列表
from rest_framework.decorators import api_view, throttle_classes
from rest_framework.throttling import UserRateThrottleclass OncePerDayUserThrottle(UserRateThrottle):rate 1/dayapi_view([GET])
throttle_classes([OncePerDayUserThrottle])
def view(request):return Response({message: Hello for today! See you tomorrow!})这些装饰器对应于 APIView上设置的策略属性。
可用的装饰器有
renderer_classes(...)
parser_classes(...)
authentication_classes(...)
throttle_classes(...)
permission_classes(...)
每个装饰器都有一个参数它必须是一个类列表或者一个类元组。 2. CBV CBV就是在url中一个路径对应一个类
在上述工程下的urls下添加如下代码 urlpatterns [path(admin/, admin.site.urls),path(, include(api.urls)),url(r^test_FBV/, views.test_FBV),url(r^test_CBV/, views.test_CBV.as_view())
]
注意当用cbv模式写url时类后面一定要用as_view()方法, 这是规定格式
然后在api下的views文件中写如以下逻辑代码
from django.views import Viewclass test_CBV(View):# 以get形式访问会执行get函数,一般情况下获取数据def get(self, *args, **kwargs):return HttpResponse(get)# 以post形式访问的话会执行post函数一般情况下发送数据def post(self, *args, **kwargs):return HttpResponse(post)
这里做几点说明:
1.cbv模式下的视图类一定要继承Views类
2. 然后重定向get, post, put请求方法等, 实现不同的请求方法实现不同的逻辑代码, api验证这部分我就不说了, 直接用restclient测试就可以了