Django Rest Framework 3.3.2 开发 RESTful API

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

generic通用视图

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

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

参考文章:

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

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

时间: 2024-12-23 18:42:44

Django Rest Framework 3.3.2 开发 RESTful API的相关文章

解决一个Django Rest Framework的JSON输出的小问题

  在服务器升级迁移过程中,遇到一个见了鬼的问题. 同样的一个API输出,在本机测试时和生产中一台机器上的输出为纯数据的json格式. 而在另一台生产机器上却为加了统计和跳转信息的另一种json格式. 由于前端用了vue.js作了数据的加载,如果同样的代码,那获取json中对象的信息显然就会发生问题. 解决BUG的时间来不及,也无法深入调试.可用以下代码,判断json中是否有存在对象来进行对象的赋值,可解决这个输出问题. 以后找时间还是深入研究一下这个DRF的输出机制吧. //此处兼容djang

camel开发restful的时候server类无法获取参数

问题描述 camel开发restful的时候server类无法获取参数 新人正在学习camel-cxf 发布一个restful 服务 get请求的时候没有问题,当提交post请求的时候server类的代码无法获取参数值 解决方案 http://reymont.iteye.com/blog/1523822

Django REST framework 的TokenAuth认证及外键Serializer基本实现

  一,Models.py中,ForeignKey记得要有related_name属性,已实现关联对象反向引用. app_name = models.ForeignKey("cmdb.App",related_name='deploy_app', verbose_name="App")   二,Settings.py文件中,加入对Django REST framework的基本设置. REST_FRAMEWORK = { 'DEFAULT_PERMISSION_CL

Yii framework框架之模块开发工作笔记

个稍微大点的项目,如果按照yii生成的webapp进行开发.所有的controller放到controllers文件夹下,所有的model放到models文件夹下面,如果你有 n 多个 controller 和 n 多的 model ,这种情况下维护代码将是一个非常痛苦的过程.为了避免这种情况,Yii 提供了一种 Modules(模块) 的目录结构方式. Modules(模块) 是一个独立的单元,包含视图.控制器和其它组件,它和一个应用的区别是不能单独部署,模块都保存在应用的 moudules

基于swagger的RESTful API开发实践

前言 RESTful架构,是目前最流行的一种互联网软件架构.它结构清晰.符合标准.易于理解.扩展方便,所以正得到越来越多网站的采用.后端通过提供一套标准的RESTful API,让网站,移动端和第三方系统都可以基于API进行数据交互和对接,极大的提高系统的开发效率,也使得前后端分离架构成为可能. 因此,不同的测试,开发团队(前端,移动端,第三方接入者等)都需要围绕API进行开发工作,API的规范和文档对于团队开发,测试变得越来越重要.除了一份标准的文档,我们还希望API能够在线测试使用,从而有更

weblogic 10.x 上开发restful服务

之前已经学习过 利用JAX-RS快速开发RESTful 服务,当时是jboss环境,如果原封不动的迁移到weblogic 10.x 版本,会杯具的发现应用启动失败,需要做些小调整: 项目结构如下: 需要在原来的Rest Service(本文中是MyService.java)外,再包装一层,创建一个Application的子类,本例中是 MyApplication.java,代码如下: 1 package yjmyzz.service; 2 3 import java.util.HashSet;

java Restlet开发restful webservice学习笔记

Restlet的简单介绍 说道java开发Restful webservie,除了JAX-RS,还有一个就是Restet.Restlet个人感觉要比JAX-RS更灵活,当然,也更复杂点. 特点 和JAX-RS类似,也可以使用注解.但是没JAX-RS那么多注解,很少,Restlet的所有注解类有(有@符号的就是): Restlet有一个特点,就是可以既作为web应用,放到tomcat之类的容器中,响应http请求.这种方式和JAX-RS差不多,都是通过一个类似于拦截器的servlet将请求拦截,然

RESTful API设计给开发人员带来怎样的未来?

业界正在逐渐承认RESTful API优于面向服务架构.但是这对于架构师和开发人员而言到底意味着什么?Tom Nolle分享了他的想法. 在模块化应用世界里,最为持久的争论莫过于面向服务架构和表述性状态转移之争了.本文探讨这样的争论带来了什么及其背后的原因. SOA已经被定性为连接组件和工作流的严格的且重量级的方案,REST则赢得了更多的赞誉.两者的特征都是简化,但是要学习RESTful API设计,架构师和开发人员必须理解SOA和REST之间的差异,学习REST和云以及微服务一起的演进,并且了

用 Flask 来写个轻博客 (35) — 使用 Flask-RESTful 来构建 RESTful API 之四

目录 目录 前文列表 POST 请求 身份认证 测试 前文列表 用 Flask 来写个轻博客 (1) - 创建项目 用 Flask 来写个轻博客 (2) - Hello World! 用 Flask 来写个轻博客 (3) - (M)VC_连接 MySQL 和 SQLAlchemy 用 Flask 来写个轻博客 (4) - (M)VC_创建数据模型和表 用 Flask 来写个轻博客 (5) - (M)VC_SQLAlchemy 的 CRUD 详解 用 Flask 来写个轻博客 (6) - (M)V