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

Use the Django framework to build RESTful APIs

PHPz
Release: 2023-09-28 21:01:50
Original
1432 people have browsed it

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
Copy after login

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

$ cd myproject
$ python manage.py startapp api
Copy after login
  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',
]
Copy after login

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')),
]
Copy after login
  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)
Copy after login

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']
Copy after login
  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
Copy after login

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
Copy after login
  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'),
]
Copy after login
  1. Start the service
    Now we can run the development server and test our API.
$ python manage.py runserver
Copy after login
  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/
    Copy after login
  • Get a single article (GET request):

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

    POST http://localhost:8000/api/articles/
    Content-Type: application/json
    
    {
      "title": "Hello",
      "content": "This is a test article."
    }
    Copy after login
  • 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."
    }
    Copy after login
  • Delete article (DELETE request):

    DELETE http://localhost:8000/api/articles/1/
    Copy after login

    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!

Related labels:
source:php.cn
Statement of this Website
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
Popular Tutorials
More>
Latest Downloads
More>
Web Effects
Website Source Code
Website Materials
Front End Template