Home >Backend Development >Python Tutorial >Use the Django framework to build RESTful APIs

Use the Django framework to build RESTful APIs

PHPz
PHPzOriginal
2023-09-28 21:01:501453browse

Use the Django framework to build RESTful APIs

Use the Django framework to build RESTful APIs

With the continuous development of web applications, building scalable and flexible APIs has become important for modern applications component. As a popular development framework, the Django framework provides us with a fast and reliable way to build RESTful APIs. This article will introduce how to use the Django framework to build a RESTful API and provide specific code examples.

  1. Creating Django Projects and Applications
    First, we need to create a Django project in the local environment. Use the following command to create a project named "myproject".
$ django-admin startproject myproject

Go to the project directory and create an application named "api".

$ cd myproject
$ python manage.py startapp api
  1. Configuring projects and applications
    In the settings.py file of the project, we need to add the "rest_framework" and "api" applications to the INSTALLED_APPS list.
INSTALLED_APPS = [
    ...
    'rest_framework',
    'api',
]

You also need to configure the urls.py file of the project to forward the request path to our API application.

from django.urls import include, path

urlpatterns = [
    ...
    path('api/', include('api.urls')),
]
  1. Creating models and serializers
    In our application API, we need to first define the model class to represent the resources in our API. Taking an article as an example, we can define a model named "Article" in the models.py file.
from django.db import models

class Article(models.Model):
    title = models.CharField(max_length=100)
    content = models.TextField()
    created_at = models.DateTimeField(auto_now_add=True)

Next, we need to create a file named serializers.py in the api directory and define a serializer named "ArticleSerializer" to convert the model instance to JSON.

from rest_framework import serializers
from api.models import Article

class ArticleSerializer(serializers.ModelSerializer):
    class Meta:
        model = Article
        fields = ['id', 'title', 'content', 'created_at']
  1. Create Views
    Create a file named views.py in the api directory and add a class view named ArticleList to handle GET and POST requests.
from rest_framework import generics
from api.models import Article
from api.serializers import ArticleSerializer

class ArticleList(generics.ListCreateAPIView):
    queryset = Article.objects.all()
    serializer_class = ArticleSerializer

We can also create a class view called ArticleDetail to handle GET, PUT and DELETE requests for a single article.

from rest_framework import generics
from api.models import Article
from api.serializers import ArticleSerializer

class ArticleDetail(generics.RetrieveUpdateDestroyAPIView):
    queryset = Article.objects.all()
    serializer_class = ArticleSerializer
  1. Configure URL
    Create a file named urls.py in the api directory and add the following code to configure the path.
from django.urls import path
from api import views

urlpatterns = [
    path('articles/', views.ArticleList.as_view(), name='article-list'),
    path('articles/<int:pk>/', views.ArticleDetail.as_view(), name='article-detail'),
]
  1. Start the service
    Now we can run the development server and test our API.
$ python manage.py runserver
  1. Testing API
    Using tools such as Postman or curl, etc., you can send HTTP requests to test the API. Here are some common API request examples.
  • Get all articles (GET request):

    GET http://localhost:8000/api/articles/
  • Get a single article (GET request):

    GET http://localhost:8000/api/articles/1/
  • Create new article (POST request):

    POST http://localhost:8000/api/articles/
    Content-Type: application/json
    
    {
      "title": "Hello",
      "content": "This is a test article."
    }
  • Update article (PUT request):

    PUT http://localhost:8000/api/articles/1/
    Content-Type: application/json
    
    {
      "title": "Hello World",
      "content": "This is an updated test article."
    }
  • Delete article (DELETE request):

    DELETE http://localhost:8000/api/articles/1/

Summary:
In this article, we introduced how to use the Django framework to build a RESTful API. By creating models and serializers, defining views and URL configurations, we can quickly build a fully functional API and test it. This provides a good foundation for us to build modern web applications and provide scalable services. Using the Django framework, we can easily handle common API needs such as getting, creating, updating, and deleting resources.

(Word count: 1063)

The above is the detailed content of Use the Django framework to build RESTful APIs. For more information, please follow other related articles on the PHP Chinese website!

Statement:
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn