S11 day 94 RestFramework 之 APIView视图
VIEW视图(Django自带的)
1. url
url(r'login/$', views.login.as_view()),
2.点开 as_view() , as_view()为类方法. login类里面没有as_view方法,所以会到继承的View类中去找as_view方法.
from django.views import View
class login(View): def get(self,request):
return HttpResponse("get请求")
def psot(self,request):
return HttpResponse("post请求")
3. views.login.as_view() 等同于执行as_view方法。
web请求后一定会有一个函数方法的返回return 那么 ,我们看到下面as_view 方法里面 定义了view方法,整个as_view函数返回的就是view
相当于:
url(r'login/$', views.login.as_view()),
==> url(r'login/$', view), 执行view ,一但用户访问login,执行的view(request,*args,**kwargs)
==>url(r'login/$', view), 执行view 一但用户方法login,执行的是 return self.dispatch(request, *args, **kwargs)
self.dispatch()
最后执行dispatch方法 ,然后再看self 是谁的实例对象 ,这个self是谁取决于cls是谁( self = cls(**initkwargs) ) ===>def as_view(cls, **initkwargs): , login 类调用的as_view ,所以 这个self实例对象为login类的self , 那么我们就去login类里去找dispatch ,发现login里面我们并没有定义dispatch, 我们就去View基类里去找dispatch ,下面的dispatch 源码就是View基类里的源码dispatch方法。下面就来看dispatch里的执行顺序
,这个self为login 的类
as_view 源码
@classonlymethod
def as_view(cls, **initkwargs):
"""
Main entry point for a request-response process.
"""
for key in initkwargs:
if key in cls.http_method_names:
raise TypeError("You tried to pass in the %s method name as a "
"keyword argument to %s(). Don't do that."
% (key, cls.__name__))
if not hasattr(cls, key):
raise TypeError("%s() received an invalid keyword %r. as_view "
"only accepts arguments that are already "
"attributes of the class." % (cls.__name__, key)) def view(request, *args, **kwargs):
self = cls(**initkwargs)
if hasattr(self, 'get') and not hasattr(self, 'head'):
self.head = self.get
self.request = request
self.args = args
self.kwargs = kwargs
return self.dispatch(request, *args, **kwargs)
view.view_class = cls
view.view_initkwargs = initkwargs # take name and docstring from class
update_wrapper(view, cls, updated=()) # and possible attributes set by decorators
# like csrf_exempt from dispatch
update_wrapper(view, cls.dispatch, assigned=())
return view
dispatch方法里面 有个getattr 方法 ,handler 就是执行login类里的譬如get方法。
dispatch执行的结果就是handler的执行结果.
handler的执行就是self.get方法
dispatch源码
def dispatch(self, request, *args, **kwargs):
# Try to dispatch to the right method; if a method doesn't exist,
# defer to the error handler. Also defer to the error handler if the
# request method isn't on the approved list.
if request.method.lower() in self.http_method_names:
handler = getattr(self, request.method.lower(), self.http_method_not_allowed)
else:
handler = self.http_method_not_allowed
return handler(request, *args, **kwargs)
APIVIEW视图(restframework带的)
1. 设置二级路由.
url 路由
from django.conf.urls import url,include
from django.contrib import admin
from app01 import app01_url #导入二级路由文件 urlpatterns = [
url(r'^admin/', admin.site.urls),
url(r'^api/', include(app01_url)), #评论.
# url(r'^comment_list/', views.comment),
# url(r'^add_comment/', views.article_list),
# url(r'^delete_comment/', views.article_list),
]
二级路由 (在app目录下创建二级路由文件)
from django.conf.urls import url
from app01 import views urlpatterns = [
url(r'^article/', views.index),
# url(r'article/(?P<pk>\d+)', views.ArticleDetail.as_view(), name='article-detail'),
# url(r'school/(?P<id>\d+)', views.SchoolDetail.as_view(), name='school-detail111'), ]
访问方法 : http://127.0.0.1:8001/api/article/
序列化 文件
from app01.models import Comment,Article,School
from rest_framework import serializers # 序列化评论类
class CommentSerializer(serializers.ModelSerializer):
class Meta:
model = Comment
fields ="__all__"
# depth = #序列化文章类
class ArticleModelSerializer(serializers.ModelSerializer):
class Meta:
model =Article
fields ="__all__" # 学校的序列化
class SchoolSerializer(serializers.ModelSerializer):
class Meta:
model =School
fields ="__all__"
2. 序列化+APIVIEW视图
A.GET请求
from rest_framework.views import APIView
from app01 import serializers as app01_serializer
from rest_framework.views import Response
class Comment(APIView):
def get(self,request):
res={"code":}
#数据
all_comment =models.Comment.objects.all()
#序列化
ser_obj =app01_serializer.CommentSerializer(all_comment,many=True)
print('ser_obj-->:',ser_obj)
res["data"] =ser_obj.data
return Response(res)
打印结果:


B.POST请求
def post(self,request):
res ={"code":}
#去提交的数据
comment_data = self.request.data
print("comment-data---------->",comment_data)
#对用户提交的数据做校验
ser_obj =app01_serializer.CommentSerializer(data=comment_data)
if ser_obj.is_valid():
# 表示数据没有问题,可以创建
ser_obj.save()
print('数据确认ok')
else:
#表示数据有问题
res["code"] =
res["error"] =ser_obj.errors
print('数据有问题')
return Response(res)
打印结果:


3. 更改报错信息.
# 序列化评论类
class CommentSerializer(serializers.ModelSerializer): class Meta:
model = Comment
fields ="__all__"
depth =
#定义额外的参数.
extra_kwargs={
"content":{
"error_messages":{
"required":"内容不能为空."
}
}
}
结果:

4 .校验钩子 Validation
#用于做校验的钩子函数,类似于form组件的clean字段.
#局部钩子
def validate_content(self,value):
if "fuck" in value:
raise ValidationError("不符合社会主义核心价值观")
else:
return value ==========以下代码没用上. #全局钩子
def validate(self, attrs):
self.validated_data # 经过校验的数据,类似于form组件里的cleaned_data
pass
结果:



在restframework 中 POST请求封装在 request.data里 ,request.data提供多种解析器 ,传json数据可以解析 ,urenccoded数据可以解析





S11 day 94 RestFramework 之 APIView视图的更多相关文章
- S11 day 95 RestFramework 之 视图
1. 基于APIVIEW视图序列化 我们会发现两个类有好多重复的代码.所以我们引入了GenericAPIView (继承了APIView) 2.Generic ApiVIew和 ListModel ...
- rest-framework之APIView 序列化组件
rest-framework之APIView 一 安装djangorestframework 方式一:pip3 install djangorestframework 方式二:pycharm图形化界面 ...
- rest-framework框架——APIView和序列化组件
一.快速实例 Quickstart http://www.cnblogs.com/yuanchenqi/articles/8719520.html restful协议 ---- 一切皆是资源,操作只是 ...
- day 94 RestFramework序列化组件与视图view
一 .复习 1. CBV流程 class BookView(View): def get(): pass def post(): pass #url(r'^books/', views.BookVie ...
- S11 day 96 RestFramework 之认证权限
一.设计一个简易的登录 1. 建立一个模型 class UserInfo(models.Model): username =models.CharField(max_length=) password ...
- rest-framework组件 之 视图三部曲
浏览目录 使用混合(mixins) mixin类编写视图 使用通用的基于类的视图 viewsets.ModelViewSet 视图三部曲 使用混合(mixins) from rest_framewor ...
- Django RestFramework(DRF)类视图
基础视图 1.基础函数视图(@api_view) DRF提供了一种函数基础视图来装饰Django的普通视图,我们可以使用request来接受请求和response响应.一个小例子: from rest ...
- 10.APIView视图
from rest_framework import status from rest_framework.response import Response from snippets.models ...
- S11 day 93 RestFramework 之 序列化
1. 表建模 from django.db import models # Create your models here. #文章表 class Article(models.Model): tit ...
随机推荐
- linux系统命令笔记
一.linux系统目录 /bin 系统命令目录 /dev 设备目录 /home 每个系统用户在home下都有一个目录, 每个用户登录到系统后会自动登录到这个目录下, root用户会在/root文件夹下 ...
- 我的UI启蒙之路
为什么叫UI启蒙之路呢? 我没有学过美术,也不懂设计,但是有的时候也许就是一种命中注定吧,让我知道了UI,并且一发不可收拾的爱上了它. 具体情况是这样的: 我毕业于电力学校,是一名不折不扣的工科生,专 ...
- shiro + struts2 在action 中使用 shiro 注解 @requiresPermissions 报错: 方法找不到,类初始失败
06:36:34,405 ERROR http-8084-2 dispatcher.Dispatcher:38 - Exception occurred during processing reque ...
- 2018秋季c语言基础课第一次作业
1)大学和高中最大的不同是没有人天天看着你,请看大学理想的师生关系是?有何感想? 答:邹欣老师提到了很多种关系,不外呼就是两种:平等或者不平等.平等的师生关系与陌生人无异,而自古以来尊师重道却被世人所 ...
- VS2010 MFC对话框程序用CButtonST给按钮添加图标
也许是VS版本的关系,CButtonST中的BCMenu两个文件是无法编译通过的. 1.拷贝下载的CButtonST(我下载的v3.9)中的BtnST.h和BtnST.cpp文件到自己项目目录下. ...
- MyEclipse配置Maven插件
一.工具环境 1.jdk-7u80-windows-x64 2.apache-tomcat-7.0.70 3.apache-maven-3.3.9 4.MyEclipse 10.7 5.windows ...
- 2018.10.22 bzoj1009: [HNOI2008]GT考试(kmp+矩阵快速幂优化dp)
传送门 f[i][j]f[i][j]f[i][j]表示从状态"匹配了前i位"转移到"匹配了前j位"的方案数. 这个东西单次是可以通过跳kmp的fail数组得到的 ...
- 2018.09.20 atcoder Painting Graphs with AtCoDeer(tarjan+polya)
传送门 一道思维题. 如果没有环那么对答案有k的贡献. 如果恰为一个环,可以用polya求贡献. 如果是一个有多个环重叠的双联通的话,直接转化为组合数问题(可以证明只要每种颜色被选取的次数相同一定可以 ...
- winform 按键控制
用ADSW来控制前后左右,J表示开火,J不能连续按 _+表示速度档位. DateTime _LastPress = DateTime.MinValue; Keys _PrevKey = Keys.No ...
- Vim配置(转)
1.按F5可以直接编译并执行C.C++.java代码以及执行shell脚本,按“F8”可进行C.C++代码的调试 2.自动插入文件头 ,新建C.C++源文件时自动插入表头:包括文件名.作者.联系方式. ...