我是Django REST框架的初学者,需要你的建议。我正在开发一个Web服务。该服务必须为其他服务提供REST接口。我需要实现的REST接口不能直接使用我的模型(我的意思是get,put,post,delete操作)。相反,它为其他服务提供了一些计算结果。根据请求,我的服务进行一些计算,然后返回结果(不将结果存储在自己的数据库中)。
以下是我对如何实现REST接口的理解。如果我错了,请纠正我。
我错过了什么吗?这种方法一般是否正确?
答案 0 :(得分:149)
Django-rest-framework即使不将它绑定到模型也能很好地工作。您的方法听起来不错,但我相信您可以修改一些步骤以使一切正常。
例如,rest框架附带了一些内置渲染器。开箱即用它可以将JSON和XML返回给API使用者。您也可以通过安装所需的python模块来启用YAML。 Django-rest-framework将输出任何基本对象,如dict,list和tuple,而无需你做任何额外的工作。
所以基本上你只需要创建接受参数的函数或类,执行所有必需的计算并将其结果返回到REST api视图的元组中。如果JSON和/或XML符合您的需求,django-rest-framework将为您处理序列化。
在这种情况下,您可以跳过第2步和第3步,只使用一个类进行计算,使用一个类进行API使用者的演示。
以下几个片段可以帮助您:
请注意我没有测试过这个。它只是作为一个例子,但它应该工作:)
CalcClass:
class CalcClass(object):
def __init__(self, *args, **kw):
# Initialize any variables you need from the input you get
pass
def do_work(self):
# Do some calculations here
# returns a tuple ((1,2,3, ), (4,5,6,))
result = ((1,2,3, ), (4,5,6,)) # final result
return result
REST视图:
from rest_framework.views import APIView
from rest_framework.response import Response
from rest_framework import status
from MyProject.MyApp import CalcClass
class MyRESTView(APIView):
def get(self, request, *args, **kw):
# Process any get params that you may need
# If you don't need to process get params,
# you can skip this part
get_arg1 = request.GET.get('arg1', None)
get_arg2 = request.GET.get('arg2', None)
# Any URL parameters get passed in **kw
myClass = CalcClass(get_arg1, get_arg2, *args, **kw)
result = myClass.do_work()
response = Response(result, status=status.HTTP_200_OK)
return response
你的urls.py:
from MyProject.MyApp.views import MyRESTView
from django.conf.urls.defaults import *
urlpatterns = patterns('',
# this URL passes resource_id in **kw to MyRESTView
url(r'^api/v1.0/resource/(?P<resource_id>\d+)[/]?$', login_required(MyRESTView.as_view()), name='my_rest_view'),
url(r'^api/v1.0/resource[/]?$', login_required(MyRESTView.as_view()), name='my_rest_view'),
)
当您访问http://example.com/api/v1.0/resource/?format=json时,此代码应输出列表列表。如果使用后缀,则可以将?format=json
替换为.json
。您还可以通过向标题添加"Content-type"
或"Accept"
来指定您希望获得的编码。
[
[
1,
2,
3
],
[
4,
5,
6
]
]
希望这可以帮助你。
答案 1 :(得分:0)
请注意,在urls.py中,login_required函数需要
from django.contrib.auth.decorators import login_required