Быстрый старт
Мы создадим простой API, который позволит администраторам просматривать и редактировать пользователей и группы в системе.
Настройка проекта
Создайте новый проект Django под названием tutorial, затем создайте новое приложение под названием quickstart.
# Create the project directory
mkdir tutorial
cd tutorial
# Create a virtual environment to isolate our package dependencies locally
python3 -m venv env
source env/bin/activate # On Windows use `env\Scripts\activate`
# Install Django and Django REST framework into the virtual environment
pip install djangorestframework
# Set up a new project with a single application
django-admin startproject tutorial . # Note the trailing '.' character
cd tutorial
django-admin startapp quickstart
cd ..Схема проекта должна выглядеть следующим образом:
Может показаться необычным, что приложение создано в каталоге проекта. Использование пространства имен проекта позволяет избежать конфликта имен с внешними модулями (эта тема выходит за рамки данного краткого руководства).
Теперь синхронизируйте базу данных в первый раз:
Мы также создадим начального пользователя с именем admin и паролем. Мы будем аутентифицироваться под этим пользователем позже в нашем примере.
После того как вы настроили базу данных и создали начального пользователя, откройте каталог приложения и приступайте к работе...
Сериализаторы
Сначала мы определим некоторые сериализаторы. Давайте создадим новый модуль tutorial/quickstart/serializers.py, который мы будем использовать для представления данных.
Обратите внимание, что в данном случае мы используем гиперссылки с помощью HyperlinkedModelSerializer. Вы также можете использовать первичный ключ и различные другие отношения, но гиперсвязь - это хороший дизайн RESTful.
Представления
Итак, нам нужно написать несколько представлений. Откройте tutorial/quickstart/views.py и начните печатать.
Вместо того, чтобы писать несколько представлений, мы объединяем все общее поведение в классы под названием ViewSets.
При необходимости мы можем легко разбить их на отдельные представления, но использование наборов представлений позволяет сохранить логику представления хорошо организованной, а также очень лаконичной.
URL-адреса
Итак, теперь давайте подключим URL-адреса API. Переходим к tutorial/urls.py...
Поскольку мы используем наборы представлений, а не представления, мы можем автоматически генерировать URL conf для нашего API, просто зарегистрировав наборы представлений в классе маршрутизатора.
Опять же, если нам нужен больший контроль над URL API, мы можем просто вернуться к использованию обычных представлений на основе классов и явного написания URL conf.
Наконец, мы включаем стандартные представления входа и выхода для использования с Web-интерфейсом API. Это необязательно, но полезно, если ваш API требует аутентификации, а вы хотите использовать Web-интерфейс API.
Пагинация
Пагинация позволяет управлять количеством возвращаемых объектов на странице. Чтобы включить эту функцию, добавьте следующие строки в tutorial/settings.py
Настройки
Добавьте 'rest_framework' в INSTALLED_APPS. Модуль настроек будет находиться в файле tutorial/settings.py.
Хорошо, мы закончили.
Тестирование нашего API
Теперь мы готовы протестировать созданный нами API. Давайте запустим сервер из командной строки.
Теперь мы можем получить доступ к нашему API как из командной строки, так и с помощью таких инструментов, как curl...
Или с помощью httpie, инструмента командной строки...
Или непосредственно через браузер, перейдя по URL-адресу http://127.0.0.1:8000/users/...

Если вы работаете через браузер, обязательно войдите в систему, используя элемент управления в правом верхнем углу.
Отлично, это было легко!
Если вы хотите получить более глубокое понимание того, как устроен DRF, перейдите к учебнику или начните просматривать руководство по API.
Last updated
Was this helpful?