一.新建立工程和app
django-admin.py startproject tutorial cd tutorial python manage.py startapp snippets
二.配置数据库
DATABASES ={'default':{'ENGINE':'django.db.backends.sqlite3','NAME':'tmp.db','USER':'','PASSWORD':'','HOST':'','PORT':'',}}
三.配置settings.py,将新建的app添加进来
INSTALLED_APPS =(...'rest_framework','snippets',)
四.配置URL
urlpatterns = patterns('', url(r'^', include('snippets.urls')),)
五.创建MODEL
from django.db import models from pygments.lexers import get_all_lexers from pygments.styles import get_all_styles LEXERS =[item for item in get_all_lexers()if item[1]] LANGUAGE_CHOICES = sorted([(item[1][0], item[0]) for item in LEXERS]) STYLE_CHOICES = sorted((item, item) for item in get_all_styles()) class Snippet(models.Model): created = models.DateTimeField(auto_now_add=True) title = models.CharField(max_length=100, blank=True, default='') code = models.TextField() linenos = models.BooleanField(default=False) language = models.CharField(choices=LANGUAGE_CHOICES, default='python', max_length=100) style = models.CharField(choices=STYLE_CHOICES, default='friendly', max_length=100) classMeta: ordering =('created',)
注意rest3.0 和 2.0版本的不一样,比如widget要用style来表示。Field要用ReadOnlyField来表示
然后同步数据库
python manage.py syncdb
七.建立一个序列化Serializer的类
我们需要为 Web API 提供序列化和逆序列化方法,用像 json 这样的数据格式来表现 snippet 数据模型。我们可以像Django的表单类那样来声明序列化器类。在 app snippets 目录下建立一个名为 serializers.py 的文件,在该文件中键入:
from django.forms import widgets from rest_framework import serializers from snippets.models importSnippet, LANGUAGE_CHOICES, STYLE_CHOICES class SnippetSerializer(serializers.Serializer): pk = serializers.Field()# Note: `Field` is an untyped read-only field. title = serializers.CharField(required=False, max_length=100) code = serializers.CharField(widget=widgets.Textarea, max_length=100000) linenos = serializers.BooleanField(required=False) language = serializers.ChoiceField(choices=LANGUAGE_CHOICES, default='python') style = serializers.ChoiceField(choices=STYLE_CHOICES, default='friendly') def restore_object(self, attrs, instance=None): """ Create or update a new snippet instance, given a dictionary of deserialized field values. 创建或者更新一个新的 snippet 实例,需要一个字典,该字典包含逆序列化域的值。 Note that if we don't define this method, then deserializing data will simply return a dictionary of items. 如果我们没有定义改方法,纳秒逆序列化数据只会简单地返回一个项目字典 """ if instance:# Update existing instance instance.title = attrs.get('title', instance.title) instance.code = attrs.get('code', instance.code) instance.linenos = attrs.get('linenos', instance.linenos) instance.language = attrs.get('language', instance.language) instance.style = attrs.get('style', instance.style) return instance # Create new instancereturnSnippet(**attrs) return Snippet(**attrs)
关于序列化类的理解:
该序列化器类的第一部分定义了需要序列化和逆序列化的域。restore_object方法定义了怎样用逆序列化的数据来创建一个新的实例。
注意:我们同样可以使用其他更多的用在表单中的属性,像 widget(3.0用style)=weidgets.Textarea。这些属性可以用来控制序列化器渲染一个 HTML 表单的行为,尤其对显示可浏览的 API 有用,这个我们会在后面的教程中看到。
我们可以用ModelSerializer类来快速生成,但是现在我们会显示地定义序列化器。
八.查看序列化是如何工作的
python manage.py shell
from snippets.models import Snippet from snippets.serializers import SnippetSerializer from rest_framework.renderers import JSONRenderer from rest_framework.parsers import JSONParser snippet =Snippet(code='foo = "bar"\n') snippet.save() snippet =Snippet(code='print "hello, world"\n') snippet.save()
上面创建一个snippets实例
获取snippets实例,查看序列化的效果:
serializer =SnippetSerializer(snippet) serializer.data# {'pk': 2, 'title': u'', 'code': u'print "hello, world"\n', 'linenos': False, 'language': u'python', 'style': u'friendly'}
上面我们将 模型的实例转换成Python数据类型。我们用序列化器将其渲染成 json:
content =JSONRenderer().render(serializer.data) content# '{"pk": 2, "title": "", "code": "print \\"hello, world\\"\\n", "linenos": false, "language": "python", "style": "friendly"}'
九.逆序列化
逆序列化是类似的,首先我们解析数据流,将其转成Python数据类型。
==JSONParser().parse(stream)
然后存储Python数据类型到对象实例中去。
serializer =SnippetSerializer(data=data) serializer.is_valid() # Trueserializer.object # <Snippet: Snippet object>
注意这些API和django表单的相似处。这些相似点, 在我们讲述在view中使用serializers时将更加明显。
我么也可以序列化 querysets,只需要简单的加上 many = True。
serializer =SnippetSerializer(Snippet.objects.all(), many=True) serializer.data# [{'pk': 1, 'title': u'', 'code': u'foo = "bar"\n', 'linenos': False, 'language': u'python', 'style': u'friendly'}, {'pk': 2, 'title': u'', 'code': u'print "hello, world"\n', 'linenos': False, 'language': u'python', 'style': u'friendly'}]