利用Django实现RESTful API(一)

利用Django实现RESTful API(一)

  RESTful API现在很流行,这里是它的介绍 理解RESTful架构和 RESTful API设计指南.按照Django的常规方法当然也可以实现REST,但有一种更快捷、强大的方法,那就是 Django REST framework.它是python的一个模块,通过在Django里面配置就可以把app的models中的各个表实现RESTful API。下面是实现方法:

一、安装配置

pip install djangorestframework
pip install markdown       # Markdown support for the browsable API.
pip install django-filter  # Filtering support

再到Django的 settings.py 中的INSTALLED_APPS添加 rest_framework,如下:

1
2
3
4
INSTALLED_APPS  =  (
     ...
     'rest_framework' ,
)

 在根目录的 url.py 文件中为rest_framework框架的 login 和 logout 视图添加url:

1
2
3
4
urlpatterns  =  [
     ...
     url(r '^api-auth/' , include( 'rest_framework.urls' , namespace = 'rest_framework' ))
]

 

二、创建model和Serializer

创建app,名为 snippets.。在视图 models.py 中添加一张表如下:

复制代码
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)

    class Meta:
        ordering = ('created',)
复制代码

然后开始同步到数据库中:

./manage.py makemigrations snippets
./manage.py migrate

接下来需要做的就是创建 Serializer 类,类似于 Form。它的作用就是从你传入的参数中提取出你需要的数据,并把它转化为 json 格式(注意,已经是字节码了),同时支持反序列化到model对象。在 snippets 文件夹中添加 serializers.py 并在其添加如下:

按 Ctrl+C 复制代码
按 Ctrl+C 复制代码

 

三、使用Serializer

先使用 ./manage.py shell 进入Django的shell中。操作如下:

可以看到 Serializer 的使用如同 Django 的 forms.它的反序列化如下:

from django.utils.six import BytesIO

stream = BytesIO(content)
data = JSONParser().parse(stream)

这是再把得到的数据转化为实例:

复制代码
serializer = SnippetSerializer(data=data)
serializer.is_valid()    # 开始验证
# True
serializer.validated_data
# OrderedDict([('title', ''), ('code', 'print "hello, world"\n'), ('linenos', False), ('language', 'python'), ('style', 'friendly')])
serializer.save()
# <Snippet: Snippet object>
复制代码

同时,我们还可以对 querysets 进行序列化,只需简单地在设置参数 many=True,如下:

serializer = SnippetSerializer(Snippet.objects.all(), many=True)
serializer.data
# [OrderedDict([('id', 1), ('title', u''), ('code', u'foo = "bar"\n'), ('linenos', False), ('language', 'python'), ('style', 'friendly')]), OrderedDict([('id', 2), ('title', u''), ('code', u'print "hello, world"\n'), ('linenos', False), ('language', 'python'), ('style', 'friendly')]), OrderedDict([('id', 3), ('title', u''), ('code', u'print "hello, world"'), ('linenos', False), ('language', 'python'), ('style', 'friendly')])

 

四、使用 ModelSerializer

ModelSerializer类似于Django的 modelform, 可以直接关联到models中的表。如下:

class SnippetSerializer(serializers.ModelSerializer):
    class Meta:
        model = Snippet
        fields = ('id', 'title', 'code', 'linenos', 'language', 'style')

 

五、在Django的视图中使用Serializer

首先,可以像常规Django视图的写法一样写,返回序列化的输出数据。

复制代码
from django.http import HttpResponse, JsonResponse
from django.views.decorators.csrf import csrf_exempt
from rest_framework.renderers import JSONRenderer
from rest_framework.parsers import JSONParser
from snippets.models import Snippet
from snippets.serializers import SnippetSerializer


@csrf_exempt
def snippet_list(request):
    """
    List all code snippets, or create a new snippet.
    """
    if request.method == 'GET':
        snippets = Snippet.objects.all()
        serializer = SnippetSerializer(snippets, many=True)
        return JsonResponse(serializer.data, safe=False)

    elif request.method == 'POST':
        data = JSONParser().parse(request)
        serializer = SnippetSerializer(data=data)
        if serializer.is_valid():
            serializer.save()
            return JsonResponse(serializer.data, status=201)
        return JsonResponse(serializer.errors, status=400)
复制代码

也可以写一个视图对应其models中的表,实现对它的删、改、查。

复制代码
@csrf_exempt
def snippet_detail(request, pk):
    """
    Retrieve, update or delete a code snippet.
    """
    try:
        snippet = Snippet.objects.get(pk=pk)
    except Snippet.DoesNotExist:
        return HttpResponse(status=404)

    if request.method == 'GET':
        serializer = SnippetSerializer(snippet)
        return JsonResponse(serializer.data)

    elif request.method == 'PUT':
        data = JSONParser().parse(request)
        serializer = SnippetSerializer(snippet, data=data)
        if serializer.is_valid():
            serializer.save()
            return JsonResponse(serializer.data)
        return JsonResponse(serializer.errors, status=400)

    elif request.method == 'DELETE':
        snippet.delete()
        return HttpResponse(status=204)
复制代码

添加对应的url, snippets/urls.py 中设置如下:

复制代码
from django.conf.urls import url
from snippets import views

urlpatterns = [
    url(r'^snippets/$', views.snippet_list),
    url(r'^snippets/(?P<pk>[0-9]+)/$', views.snippet_detail),
]
复制代码

最后还要在根目录的 url.py 中添加对应的映射。

urlpatterns = [  
  ...
    url(r'^', include('snippets.urls')),
]

这时,所有的配置已经完成了。接下来就是测试我们的API

六、测试API

为了方便我们可以使用 httpie 模块来测试,启动Django,再在客户端输入 http://127.0.0.1:8000/snippets/,操作如下:

 还可以进行 put 操作,修改对应的内容

如此简单。。。。。。。

  • 2
    点赞
  • 12
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: Django的弱点可能包括: 1. 性能问题:相较于轻量级框架,Django的开销比较大,可能需要更多的计算资源来支持同等请求负载。 2. 灵活性问题:Django的约束较强,如果需要定制化开发,可能需要花费更多时间和精力进行深入研究。 3. API支持问题:相较于其他框架,DjangoRESTful API的支持相对较弱,可能需要借助第三方库进行开发。 4. 缓存机制问题:Django的缓存机制相对来说比较简单,可能需要自行扩展或使用第三方缓存库进行优化。 5. 复杂度问题:Django是一个全栈框架,涵盖了许多方面的功能,因此使用和开发难度相对较高,特别是对初学者来说可能较为陡峭。 ### 回答2: Django是一种流行的Python Web框架,具有强大的功能和广泛的应用。然而,Django目前在以下几个方面可能相对较弱: 1. 前端开发能力:Django主要关注后端的构建和数据处理,对于前端开发来说,可能相对较弱。Django默认使用模板语言进行页面渲染,而不是像React或Vue这样的现代JavaScript框架,因此在构建富交互性的前端界面时可能会相对困难。 2. 扩展能力:Django提供了许多内置的功能和扩展,使得使用起来非常方便。然而,当需要实现一些非常定制化的功能时,可能需要编写大量的自定义代码,这可能相对较麻烦。相比之下,像Flask这样的微框架则更容易进行灵活的扩展。 3. 高并发支持:虽然Django在处理一般的网站流量时表现良好,但在高并发的情况下,可能相对较弱。由于Python的全局解释器锁(GIL),Django在同一时间只能处理一个请求。为了应对高并发场景,可能需要使用诸如Gunicorn或uWSGI等服务器部署方案。 4. 学习曲线:相对于其他Python Web框架来说,Django的学习曲线可能较陡峭。Django拥有丰富的功能和复杂的概念,对于初学者来说可能需要花费更多的时间来理解和熟悉。 尽管Django在某些方面可能相对较弱,但它仍然是一种非常强大和流行的Web开发框架,可以帮助开发人员快速构建稳定和可靠的Web应用程序。当然,在选择使用Django时,我们需要根据具体需求和项目特点来进行权衡和决策。 ### 回答3: Django是一个功能强大的Web开发框架,但它也存在一些相对较弱的方面。 1. 缺乏前端开发支持:Django主要关注于后端开发,对于前端开发支持较弱。虽然有一些内置的前端模板和表单功能,但在处理复杂的前端逻辑和用户体验方面,Django的支持相对较弱。在这种情况下,通常需要使用其他前端框架或工具来弥补这一不足,例如Vue.js或React等。 2. 数据库迁移复杂:Django的数据库迁移工具可以帮助我们管理数据库模式的变更,但在某些情况下,数据库迁移可能会变得复杂且困难。尤其是在项目规模较大、模型关系复杂的情况下,数据库迁移可能会遇到一些问题,例如数据冲突、迁移顺序等。因此,开发者需要特别关注和处理数据库迁移相关的问题。 3. 性能问题:尽管Django是一个成熟、稳定的框架,但在处理大规模高并发的情况下,性能可能会成为一个问题。Django的一些特性和设计选择可能导致性能较低,例如全局锁、ORM性能损耗等。为了提升性能,可能需要对代码进行优化,使用缓存策略,或者考虑使用其他性能更高的框架或库。 4. 学习曲线较陡峭:由于Django是一个功能强大的框架,学习Django可能需要一定的时间和精力。特别是对于新手来说,掌握Django的业务逻辑、开发模式和最佳实践可能会有一定的挑战。因此,初学者可能需要花更多的时间去理解和学习Django的相关概念和技术。 虽然Django在某些方面相对较弱,但它仍然是一个非常受欢迎和广泛应用的Web开发框架。通过深入了解Django的特性和注意相关的弱点,开发者可以更好地利用Django来构建高质量的Web应用。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值