REST之视图
GET :从服务器取出资源(一项或多项)
POST :在服务器新建一个资源
PUT :在服务器更新资源(客户端提供改变后的完整资源)
PATCH :在服务器更新资源(客户端提供改变的属性)
DELETE :从服务器删除资源
book为例:
"books/$" GET:获取所有数据
POST:添加一条数据
"Book/1" GET:获取单条数据
DELETE:删除一条数据
PUT/PATCH:更新一条数据
不加id的url
获取数据
url.py
url(r'^books/$',views.BookView.as_view()),
serializer.py
from app01.models import Book
class BookSerializers(serializers.ModelSerializer):
class Meta:
model=Book
# 序列化所有数据,与exclude不能并存
fields="__all__"
# # 这样加上去之后,就是不要他创建的字段了,用我自己写的自定义字段,有的话覆盖,没有的话添加
#
# publish=serializers.CharField(source='publish.name',read_only=True)
#
# # SerializerMethodField 声明这是个多对多字段
# authors=serializers.SerializerMethodField(read_only=True)
# # 声明好多对多字段,底下紧跟着定义一个方法
# # 此时的obj就是你循环book_list的obj对象
# def get_authors(self,obj):
# data=[]
# # for 循环 对象关联Author表所有的对象
# for i in obj.authors.all():
# temp = []
# temp.append(i.pk)
# temp.append(i.name)
# data.append(temp)
# return data
views.py
from rest_framework.views import APIView
from app01.serializer import PublishSerializers,BookSerializers
from app01.models import Book
class BookView(APIView):
def get(self,request):
book_list=Book.objects.all()
ps=BookSerializers(book_list,many=True)
# 序列化完成的数据
return Response(ps.data)
添加一条数据
请先阅读上一篇文章:Rest framework-request.data
views.py
class BookView(APIView):
def get(self,request):
book_list=Book.objects.all()
ps=BookSerializers(book_list,many=True)
# 序列化完成的数据
return Response(ps.data)
def post(self,request):
# 添加一条数据
# request.POST 在发JSON数据的时候是取不到值的,只有发urlecoding,orm-data才会有值
# REST已经对request再次封装了,发送JSON,urlecoding,form-data等常用等常用的数据都封装到data里了,这样就解决了request.POST 在发JSON数据的时候是取不到值的情况
print("data",request.data)
print("POST",request.POST)
# 生成一条记录
bs=BookSerializers(data=request.data)
# 校验成功后生成记录
if bs.is_valid():
bs.save()
# 把添加的数据序列化返回
return Response(bs.data)
else:
# 校验失败返回错误信息
return Response(bs.errors)
加id的url
"books/$" GET:获取所有数据
POST:添加一条数据
# 上边的我们上边已经演示过了
"Book/1" GET:获取单条数据
DELETE:删除一条数据
PUT/PATCH:更新一条数据
urls.py
url(r'^books/$',views.BookView.as_view()),
# ?P<> 分组
url(r'^books/(?P<pk>\d+)/$',views.BookDetailView.as_view()),
views.py
from rest_framework.views import APIView
from app01.models import Book
class BookView(APIView):
def get(self,request):
book_list=Book.objects.all()
ps=BookSerializers(book_list,many=True)
# 序列化完成的数据
return Response(ps.data)
def post(self,request):
# 添加一条数据
# request.POST 在发JSON数据的时候是取不到值的,只有发urlecoding,orm-data才会有值
# REST已经对request再次封装了,发送JSON,urlecoding,form-data等常用等常用的数据都封装到data里了,这样就解决了request.POST 在发JSON数据的时候是取不到值的情况
print("data",request.data)
print("POST",request.POST)
# 生成一条记录
bs=BookSerializers(data=request.data)
# 校验成功后生成记录
if bs.is_valid():
bs.save()
# 把添加的数据序列化返回
return Response(bs.data)
else:
# 校验失败返回错误信息
return Response(bs.errors)
class BookDetailView(APIView):
def get(self,request,pk):
# 根据pk值获取数据库对应的一条对象
book_obj=Book.objects.filter(pk=pk).first()
# 序列化一个对象,默认就为False
bs=BookSerializers(book_obj,many=False)
return Response(bs.data)
def put(self,request,pk):
book_obj=Book.objects.filter(pk=pk).filter()
# 更新一定要传两个值
# 第一个这次更新传进来的数据(data=request.data)
# 第二个要更新的对象(instance=book_obj)
bs=BookSerializers(data=request.data,instance=book_obj)
if bs.is_valid():
# 如果校验成功就updata
bs.save()
# 返回更新后的数据
return Response(bs.data)
else:
# 返回错误信息
return Response(bs.errors)
def delete(self,request,pk):
Book.objects.filter(pk=pk).delete()
return Response("OK")
GET:http://127.0.0.1:8000/books/2/
PUT:http://127.0.0.1:8000/books/2/
DELETE:http://127.0.0.1:8000/books/2/
现在我们在来看下所有数据
额外知识
Django seetings.py
配置文件中默认没有 APPEND_SLASH
这个参数,但 Django
默认这个参数为 APPEND_SLASH = True
。 作用就是自动在网址结尾加'/'。
默认地,任何不匹配或尾部没有斜杠(/)的申请URL,将被重定向至尾部包含斜杠的相同字眼的URL。
当 seetings.py
设置为 APPEND_SLASH = False
时,访问 网址最后不加/ 将会返回 404
1、第一次路径匹配成功该返回什么返回什么
2、如果:第一次路径匹配发现匹配不成功,但是再带个/就就匹配成功了,Django会告诉路由器你再带个url后面再加个/过来get请求发过来吧,所以是发了两次请求,你仔细看下url地址栏的变化