freshcrate
Home > Frameworks > djangorestframework

djangorestframework

Web APIs for Django, made easy.

Description

# [Django REST framework][docs] [![build-status-image]][build-status] [![coverage-status-image]][codecov] [![pypi-version]][pypi] **Awesome web-browsable Web APIs.** Full documentation for the project is available at [https://www.django-rest-framework.org/][docs]. --- # Overview Django REST framework is a powerful and flexible toolkit for building Web APIs. Some reasons you might want to use REST framework: * The Web browsable API is a huge usability win for your developers. * [Authentication policies][authentication] including optional packages for [OAuth1a][oauth1-section] and [OAuth2][oauth2-section]. * [Serialization][serializers] that supports both [ORM][modelserializer-section] and [non-ORM][serializer-section] data sources. * Customizable all the way down - just use [regular function-based views][functionview-section] if you don't need the [more][generic-views] [powerful][viewsets] [features][routers]. * [Extensive documentation][docs], and [great community support][group]. **Below**: *Screenshot from the browsable API* ![Screenshot][image] ---- # Requirements * Python 3.10+ * Django 4.2, 5.0, 5.1, 5.2, 6.0 We **highly recommend** and only officially support the latest patch release of each Python and Django series. # Installation Install using `pip`... pip install djangorestframework Add `'rest_framework'` to your `INSTALLED_APPS` setting. ```python INSTALLED_APPS = [ # ... "rest_framework", ] ``` # Example Let's take a look at a quick example of using REST framework to build a simple model-backed API for accessing users and groups. Start up a new project like so... pip install django pip install djangorestframework django-admin startproject example . ./manage.py migrate ./manage.py createsuperuser Now edit the `example/urls.py` module in your project: ```python from django.contrib.auth.models import User from django.urls import include, path from rest_framework import routers, serializers, viewsets # Serializers define the API representation. class UserSerializer(serializers.HyperlinkedModelSerializer): class Meta: model = User fields = ["url", "username", "email", "is_staff"] # ViewSets define the view behavior. class UserViewSet(viewsets.ModelViewSet): queryset = User.objects.all() serializer_class = UserSerializer # Routers provide a way of automatically determining the URL conf. router = routers.DefaultRouter() router.register(r"users", UserViewSet) # Wire up our API using automatic URL routing. # Additionally, we include login URLs for the browsable API. urlpatterns = [ path("", include(router.urls)), path("api-auth/", include("rest_framework.urls", namespace="rest_framework")), ] ``` We'd also like to configure a couple of settings for our API. Add the following to your `settings.py` module: ```python INSTALLED_APPS = [ # ... make sure to include the default installed apps here. "rest_framework", ] REST_FRAMEWORK = { # Use Django's standard `django.contrib.auth` permissions, # or allow read-only access for unauthenticated users. "DEFAULT_PERMISSION_CLASSES": [ "rest_framework.permissions.DjangoModelPermissionsOrAnonReadOnly", ] } ``` That's it, we're done! ./manage.py runserver You can now open the API in your browser at `http://127.0.0.1:8000/`, and view your new 'users' API. If you use the `Login` control in the top right corner you'll also be able to add, create and delete users from the system. You can also interact with the API using command line tools such as [`curl`](https://curl.haxx.se/). For example, to list the users endpoint: $ curl -H 'Accept: application/json; indent=4' -u admin:password http://127.0.0.1:8000/users/ [ { "url": "http://127.0.0.1:8000/users/1/", "username": "admin", "email": "admin@example.com", "is_staff": true, } ] Or to create a new user: $ curl -X POST -d username=new -d email=new@example.com -d is_staff=false -H 'Accept: application/json; indent=4' -u admin:password http://127.0.0.1:8000/users/ { "url": "http://127.0.0.1:8000/users/2/", "username": "new", "email": "new@example.com", "is_staff": false, } # Documentation & Support Full documentation for the project is available at [https://www.django-rest-framework.org/][docs]. For questions and support, use the [REST framework discussion group][group], or `#restframework` on libera.chat IRC. # Security Please see the [security policy][security-policy]. [build-status-image]: https://github.com/encode/django-rest-framework/actions/workflows/main.yml/badge.svg [build-status]: https://github.com/encode/django-rest-framework/actions/workflows/main.yml [coverage-status-image]: https://img.shields.io/codecov/c/github/encode/django-rest-framework/main.svg [codecov]: https://codecov.io/github/encode/django-rest-framework?branch=main [pypi-version]: h

Release History

VersionChangesUrgencyDate
3.17.1Imported from PyPI (3.17.1)Low4/21/2026
3.15.0## What's Changed _Released 15th March 2024_ * Django 5.0 and Python 3.12 support [[#9157](https://github.com/encode/django-rest-framework/pull/9157)] * Use POST method instead of GET to perform logout in browsable API [[9208](https://github.com/encode/django-rest-framework/pull/9208)] * Added jQuery 3.7.1 support & dropped previous version [[#9094](https://github.com/encode/django-rest-framework/pull/9094)] * Use str as default path converter [[#9066](https://github.com/encode/django-rHigh4/19/2026
3.17.0<!-- Release notes generated using configuration in .github/release.yml at 3.17.0 --> ## What's Changed ### Breaking changes * Drop support for Python 3.9 by @auvipy in https://github.com/encode/django-rest-framework/pull/9781 * Drop deprecated coreapi support by @browniebroke in https://github.com/encode/django-rest-framework/pull/9895 ### Features * Add ability to specify output format for `DurationField` by @sevdog in https://github.com/encode/django-rest-framework/pull/8532 * Add missing deLow3/18/2026
3.16.1This release fixes a few bugs, clean-up some old code paths for unsupported Python versions and improve translations. ## Minor changes * Cleanup optional `backports.zoneinfo` dependency and conditions on unsupported Python 3.8 and lower in [#9681](https://github.com/encode/django-rest-framework/pull/9681). Python versions prior to 3.9 were already unsupported so this isn't considered as a breaking change. ## Bug fixes * Fix regression in `unique_together` validation with `SerializerMLow8/6/2025
3.16.0This release is considered a significant release to improve upstream support with Django and Python. Some of these may change the behaviour of existing features and pre-existing behaviour. Specifically, some fixes were added to around the support of `UniqueConstraint` with nullable fields which will improve built-in serializer validation. ## Features * Add official support for Django 5.1 and its new `LoginRequiredMiddleware` in [#9514](https://github.com/encode/django-rest-framework/pull/9Low3/28/2025
3.15.2## What's Changed * Add @api_view example to caching documentation by @BradWells in https://github.com/encode/django-rest-framework/pull/9131 * Update docstring by @jthevos in https://github.com/encode/django-rest-framework/pull/9340 * Apply black formatting to caching markdown by @jthevos in https://github.com/encode/django-rest-framework/pull/9341 * Update renderers documentation example by @mgaligniana in https://github.com/encode/django-rest-framework/pull/9362 * Removing live examples Low12/28/2024
3.15.1## What's Changed * Update the message to be consistent with the Django `HttpResponseBa… by @maycuatroi in https://github.com/encode/django-rest-framework/pull/9287 * Make `inflection` package truly optional by @browniebroke in https://github.com/encode/django-rest-framework/pull/9303 * Fix broken links in release notes for 3.15 by @browniebroke in https://github.com/encode/django-rest-framework/pull/9305 * TokenAdmin.autocomplete_fields Breaks Some Use Cases, Revert by @alexdlaird in https:Low5/6/2024
3.14.0* Django 2.2 is no longer supported. #8662 * Django 4.1 compatibility. #8591 * Add `--api-version` CLI option to `generateschema` management command. #8663 * Enforce `is_valid(raise_exception=False)` as a keyword-only argument. #7952 * Stop calling `set_context` on Validators. #8589 * Return `NotImplemented` from `ErrorDetails.__ne__`. #8538 * Don't evaluate `DateTimeField.default_timezone` when a custom timezone is set. #8531 * Make relative URLs clickable in Browseable API. #8464 * SupLow11/8/2022
3.13.1* Revert schema naming changes with function based `@api_view`. #8297Low11/8/2022
3.13.0* Django 4.0 compatability. #8178 * Add `max_length` and `min_length` options to `ListSerializer`. #8165 * Add `get_request_serializer` and `get_response_serializer` hooks to `AutoSchema`. #7424 * Fix OpenAPI representation of null-able read only fields. #8116 * Respect `UNICODE_JSON` setting in API schema outputs. #7991 * Fix for `RemoteUserAuthentication`. #7158 * Make Field constructors keyword-only. #7632Low11/8/2022
3.12.4Release 3.12.4Low5/31/2021
3.9.3This is the last Django REST Framework release that will support Python 2. Be sure to upgrade to Python 3 before upgrading to Django REST Framework 3.10. * Adjusted the compat check for django-guardian to allow the last guardian version (v1.4.9) compatible with Python 2. #6613Low4/29/2019
3.9.2See [Release Notes](https://www.django-rest-framework.org/community/release-notes/#392) for details.Low3/3/2019
3.9.1Change Notes: https://www.django-rest-framework.org/community/release-notes/#39x-series Low2/28/2019
3.9.0Release announcement: https://www.django-rest-framework.org/community/3.9-announcement/ Change Notes: https://www.django-rest-framework.org/community/release-notes/#39x-series Low2/28/2019
3.8.2Point release for 3.8.x series * Fix `read_only` + `default` `unique_together` validation. #5922 * authtoken.views import coreapi from rest_framework.compat, not directly. #5921 * Docs: Add missing argument 'detail' to Route #5920Low4/6/2018
3.8.1* Use old `url_name` behavior in route decorators #5915 For `list_route` and `detail_route` maintain the old behavior of `url_name`, basing it on the `url_path` instead of the function name. Low4/4/2018
3.8.0* [Release Announcement](http://www.django-rest-framework.org/topics/3.8-announcement/) * [3.8.0 Milestone](https://github.com/encode/django-rest-framework/milestone/61?closed=1) * **Breaking Change**: Alter `read_only` plus `default` behaviour. #5886 `read_only` fields will now **always** be excluded from writable fields. Previously `read_only` fields with a `default` value would use the `default` for create and update operations. In order to maintain the old behaviour Low4/3/2018
3.7.7Point release for 3.7.x Note: 3.7.5-3.7.7 fixed packaging issues introduced by changes in 3.7.4. That's it. Use 3.7.7.Low1/11/2018
3.7.4Point Release for 3.7.x series. * Schema: Extract method for `manual_fields` processing #5633 Allows for easier customisation of `manual_fields` processing, for example to provide per-method manual fields. `AutoSchema` adds `get_manual_fields`, as the intended override point, and a utility method `update_fields`, to handle by-name field replacement from a list, which, in general, you are not expected to override. Note: `AutoSchema.__init__` now ensures `manuLow12/20/2017
3.7.3* Fix `AppRegistryNotReady` error importing contrib.auth views #5567 Low11/6/2017
3.7.2Point release for 3.7.x * Fixed Django 2.1 compatibility due to removal of django.contrib.auth.login()/logout() views. #5510 * Add missing import for TextLexer. #5512 * Adding examples and documentation for caching #5514 * Include date and date-time format for schema generation #5511 * Use triple backticks for markdown code blocks #5513 * Interactive docs - make bottom sidebar items sticky #5516 * Clarify pagination system check #5524 * Stop JSONBoundField mangling invalid JSON #5527 Low11/6/2017
3.7.1 * Fix Interactive documentation always uses false for boolean fields in requests #5492 * Improve compatibility with Django 2.0 alpha. #5500 #5503 * Improved handling of schema naming collisions #5486 * Added additional docs and tests around providing a default value for dotted `source` fields #5489 [3.7.1 Milestone](https://github.com/encode/django-rest-framework/milestone/58?closed=1)Low10/16/2017
3.7.0Headline feature is the ability to add per-view customisation to schema generation. * Release Announcement: http://www.django-rest-framework.org/topics/3.7-announcement/ * 3.7.0 Milestone: https://github.com/encode/django-rest-framework/milestone/49?closed=1 Low10/6/2017

Dependencies & License Audit

Loading dependencies...

Similar Packages

pre-commitA framework for managing and maintaining multi-language pre-commit hooks.v4.6.0
azure-core-tracing-opentelemetryMicrosoft Azure Azure Core OpenTelemetry plugin Library for Pythonazure-template_0.1.0b6187637
spdx-toolsSPDX parser and tools.0.8.5
lacesDjango components that know how to render themselves.0.1.2
django-tasksA backport of Django's built in Tasks framework0.12.0