好吧,首先你可以使用
django-piston,正如@Tudorizer已经提到的那样.
但话说回来,正如我所看到的那样(我可能错了!),REST更多的是一套设计指南,而不是具体的API.它本质上说的是与您的服务的交互不应该基于“您可以做的事情”(典型的RPC风格的方法),而是“事物,您可以以可预测的方式采取行动,以某种方式组织”( ‘资源’实体和http动词).
话虽这么说,使用django编写REST风格的服务并不需要任何额外的东西.
考虑以下:
# urlconf
from django.conf.urls.defaults import patterns, url
urlpatterns = patterns('',
url(r'^tickets$', 'myapp.views.tickets', name='tickets'),
url(r'^ticket/(?P\d+)$', 'myapp.views.tickets', name='ticket'),
url(r'^ticket$', 'myapp.views.tickets', name='ticket'),
)
# views
def tickets(request):
tickets = Ticket.objects.all()
return render_to_response('tickets.html', {'tickets':tickets})
def ticket(request, id=None):
if id is not None:
ticket = get_object_or_404(Ticket, id=id)
if request.method == 'POST':
# create or update ticket here
else:
# just render the ticket (GET)
...
… 等等.
重要的是您的服务如何向其用户公开,而不是它使用的库/工具包/框架.