mirror of
https://github.com/encode/django-rest-framework.git
synced 2025-01-25 00:34:21 +03:00
31 lines
1.2 KiB
ReStructuredText
31 lines
1.2 KiB
ReStructuredText
|
Using Django REST framework Mixin classes
|
||
|
=========================================
|
||
|
|
||
|
This example demonstrates creating a REST API **without** using Django REST framework's :class:`.Resource` or :class:`.ModelResource`,
|
||
|
but instead using Django :class:`View` class, and adding the :class:`EmitterMixin` class to provide full HTTP Accept header content negotiation,
|
||
|
a browseable Web API, and much of the other goodness that Django REST framework gives you for free.
|
||
|
|
||
|
.. note::
|
||
|
|
||
|
A live sandbox instance of this API is available for testing:
|
||
|
|
||
|
* http://api.django-rest-framework.org/mixin/
|
||
|
|
||
|
You can browse the API using a web browser, or from the command line::
|
||
|
|
||
|
curl -X GET http://api.django-rest-framework.org/mixin/
|
||
|
|
||
|
|
||
|
URL configuration
|
||
|
-----------------
|
||
|
|
||
|
Everything we need for this example can go straight into the URL conf...
|
||
|
|
||
|
``urls.py``
|
||
|
|
||
|
.. include:: ../../examples/mixin/urls.py
|
||
|
:literal:
|
||
|
|
||
|
That's it. Auto-magically our API now supports multiple output formats, specified either by using standard HTTP Accept header content negotiation, or by using the `&_accept=application/json` style parameter overrides.
|
||
|
We even get a nice HTML view which can be used to self-document our API.
|