Django Rest Framework 3.3.2 开发 RESTful API

简介: Python Version:     2.7.10Django Version:     1.9REST framework 3.3.2安装pip install djangopip install djangorestframeworksettings.py INSTALLED_APPS中引入rest_frameworkINSTALLED_APPS = [    'dja

Python Version:     2.7.10
Django Version:     1.9
REST framework 3.3.2


安装

pip install django

pip install djangorestframework



settings.py INSTALLED_APPS中引入rest_framework

INSTALLED_APPS = [
    'django.contrib.admin',
    'django.contrib.auth',
    'django.contrib.contenttypes',
    'django.contrib.sessions',
    'django.contrib.messages',
    'django.contrib.staticfiles',
    'app01',
    'rest_framework',
]


创建model, 修改mdels.py

class Book(models.Model):
   name=models.CharField(max_length=100)
   title=models.CharField(max_length=100)
   author=models.CharField(max_length=100)


创建serializers.py

from app01.models import *
from rest_framework import serializers

class BookSerializer(serializers.Serializer):

    name = serializers.CharField(max_length=100)
    title = serializers.CharField(max_length=100)
    author = serializers.CharField(max_length=100)
    
    def create(self, validated_data):
        return Book(**validated_data)

    def update(self, instance, validated_data):
        instance.email = validated_data.get('name', instance.name)
        instance.content = validated_data.get('title', instance.title)
        instance.created = validated_data.get('author', instance.author)
        return instance


restore_object() 3.0以上版本不支持已经被create()和update()方法代替,源码如下:

(
    'Serializer `%s.%s` has old-style version 2 `.restore_object()` '
    'that is no longer compatible with REST framework 3. '
    'Use the new-style `.create()` and `.update()` methods instead.' %
    (self.__class__.__module__, self.__class__.__name__)
)



创建基于类和函数的视图

from django.shortcuts import render_to_response
from django.http import HttpResponse
from app01.forms import *
from rest_framework.views import APIView
from app01.serializers import BookSerializer
from app01.models import *
from rest_framework.response import Response
from rest_framework import generics
from rest_framework import status

# Create your views here.

class BookList(APIView):
   def get(self,request,format=None):
      books=Book.objects.all()
      ser=BookSerializer(books, many=True)
      return Response(ser.data)

   def post(self,request,format=None):
      ser=BookSerializer(data = request.data)
      if ser.is_valid():
         ser.create(ser.validated_data).save()
         return Response(ser.data,status = status.HTTP_201_CREATED)
      return Response(ser.errors)

class BookDetail(APIView):
   def get(self,request,num,format=None):
      b=Book.objects.get(id=num)
      ser=BookSerializer(b)
      return Response(ser.data)

class GenericBookList(generics.ListCreateAPIView):
   queryset = Book.objects.all()
   serializer_class = BookSerializer
   def post(self,request,format=None):
      ser=BookSerializer(data = request.data)
      if ser.is_valid():
         ser.create(ser.validated_data).save()
         return Response(ser.data,status = status.HTTP_201_CREATED)
      return Response(ser.errors)

def index(request):
   return render_to_response('index.html')

def hello(request):
   if request.method == 'POST':
      form = BookForms(request.POST)
      if form.is_valid():
         data = form.cleaned_data
         title = data["title"]
         return HttpResponse(title)
   form = BookForms()
   return render_to_response('1.html', {'form':form})


urls.py配置

from django.conf.urls import url
from django.contrib import admin
from app01.views import *
urlpatterns = [
    url(r'^admin/', admin.site.urls),
   url(r'^$', index),
    url(r'^hello/$', hello),
    url(r'^book/$', BookList.as_view()),
    url(r'^genericbook/$', GenericBookList.as_view()),
    url(r'^book/(\d+)', BookDetail.as_view()),

]


APIView

wKioL1Z75vfQq6uPAABzO-cLj8Q983.png



generic通用视图

wKiom1Z755yiV9HXAABo7Ft4pkM974.png



RESTful Request:GET/PUT/DELETE/POST/HEAD/OPTIONS

POST请求被定义为创建“从属资源”(拥有父资源的资源) (add)

参考文章:

http://www.lifelaf.com/blog/?p=156


本文出自 “点滴积累” 博客,请务必保留此出处http://tianxingzhe.blog.51cto.com/3390077/1728016

目录
相关文章
|
13天前
|
JSON API 数据处理
【Swift开发专栏】Swift中的RESTful API集成实战
【4月更文挑战第30天】本文探讨了在Swift中集成RESTful API的方法,涉及RESTful API的基础概念,如HTTP方法和设计原则,以及Swift的网络请求技术,如`URLSession`、`Alamofire`和`SwiftyJSON`。此外,还强调了数据处理、错误管理和异步操作的重要性。通过合理利用这些工具和策略,开发者能实现高效、稳定的API集成,提升应用性能和用户体验。
|
2天前
|
缓存 测试技术 API
RESTful API的最佳实践
【5月更文挑战第11天】在Python中构建RESTful API时,可以选择轻量级的Flask或全栈的Django框架。Flask适用于小型到中型API,而Django适合大型复杂项目。示例代码展示了如何在两个框架中创建任务列表API。
5 0
|
6天前
|
存储 缓存 JavaScript
深入理解RESTful API设计原则与实践
【5月更文挑战第7天】在现代Web服务开发中,表述性状态传递(REST)是一种广泛采用的架构风格,用于构建可扩展的网络应用程序接口(APIs)。本文将探讨RESTful API的核心设计原则,并通过具体实例展示如何实现一个符合REST约束的后端服务。我们将讨论资源的识别、客户端-服务器通信模式、无状态性、以及统一接口的重要性,并探索如何使用当前的流行技术栈来实现这些概念。
|
13天前
|
缓存 监控 JavaScript
Node.js中构建RESTful API的最佳实践
【4月更文挑战第30天】本文介绍了在Node.js中构建RESTful API的最佳实践:选择合适的框架(如Express、Koa)、设计清晰的API接口(遵循HTTP动词和资源路径)、实现认证授权(JWT、OAuth 2.0)、错误处理、限流缓存、编写文档和测试,以及监控性能优化。这些实践有助于创建健壮、可维护和易用的API。
|
13天前
|
分布式计算 DataWorks 关系型数据库
DataWorks操作报错合集之在DataWorks同步数据时,遇到乱码问题,该怎么解决(rest api数据源)
DataWorks是阿里云提供的一站式大数据开发与治理平台,支持数据集成、数据开发、数据服务、数据质量管理、数据安全管理等全流程数据处理。在使用DataWorks过程中,可能会遇到各种操作报错。以下是一些常见的报错情况及其可能的原因和解决方法。
22 0
|
13天前
|
存储 关系型数据库 Go
【Go语言专栏】基于Go语言的RESTful API开发
【4月更文挑战第30天】本文介绍了使用Go语言开发RESTful API的方法,涵盖了路由、请求处理、数据存储和测试关键点。RESTful API基于HTTP协议,无状态且使用标准方法表示操作。在Go中,通过第三方库如`gorilla/mux`进行路由映射,使用`net/http`处理请求,与数据库交互可选ORM库`gorm`,测试则依赖于Go内置的`testing`框架。Go的简洁性和并发性使得它成为构建高效API的理想选择。
|
13天前
|
机器学习/深度学习 算法 安全
深度学习在图像识别中的应用与挑战构建高效可扩展的RESTful API:后端开发的实战指南
【4月更文挑战第30天】 随着计算机视觉技术的飞速发展,深度学习在图像识别领域取得了显著的成果。本文将探讨深度学习技术在图像识别中的应用及其所面临的挑战。首先,我们将介绍深度学习的基本原理和关键技术,然后分析其在图像识别中的优势和应用案例。最后,我们将讨论当前深度学习在图像识别领域所面临的主要挑战和未来的发展趋势。
|
14天前
|
XML JSON API
【PHP开发专栏】PHP RESTful API设计与开发
【4月更文挑战第29天】本文探讨了在Web开发中流行的前后端分离模式,重点介绍了RESTful API的设计与实现。REST是一种基于HTTP协议的架构风格,核心概念包括资源、表述和状态转换。RESTful API设计遵循无状态、统一接口等原则,使用GET、POST、PUT、DELETE等HTTP方法执行操作,并通过状态码和JSON/XML传输数据。在PHP中实现RESTful API,可通过定义路由、创建控制器、处理请求和响应,同时注意安全性措施,如使用HTTPS。文中还提供了一个用户管理API的实战示例,以帮助读者更好地理解和应用RESTful API。
|
14天前
|
缓存 监控 API
|
14天前
|
JSON 安全 API
【专栏】四种REST API身份验证方法:基本认证、OAuth、JSON Web Token(JWT)和API密钥
【4月更文挑战第28天】本文探讨了四种REST API身份验证方法:基本认证、OAuth、JSON Web Token(JWT)和API密钥。基本认证简单但不安全;OAuth适用于授权第三方应用;JWT提供安全的身份验证信息传递;API密钥适合内部使用。选择方法时需平衡安全性、用户体验和开发复杂性。