Rumah > pembangunan bahagian belakang > Tutorial Python > Gunakan rangka kerja Django untuk membina API RESTful

Gunakan rangka kerja Django untuk membina API RESTful

PHPz
Lepaskan: 2023-09-28 21:01:50
asal
1467 orang telah melayarinya

Gunakan rangka kerja Django untuk membina API RESTful

Bina API RESTful menggunakan rangka kerja Django

Dengan pembangunan berterusan aplikasi web, membina API berskala dan fleksibel telah menjadi bahagian penting dalam aplikasi moden. Sebagai rangka kerja pembangunan yang popular, rangka kerja Django memberikan kami cara yang pantas dan boleh dipercayai untuk membina API RESTful. Artikel ini akan memperkenalkan cara menggunakan rangka kerja Django untuk membina API RESTful dan menyediakan contoh kod khusus.

  1. Mencipta Projek dan Aplikasi Django
    Pertama, kita perlu mencipta projek Django dalam persekitaran tempatan kita. Gunakan arahan berikut untuk mencipta projek bernama "myproject".
$ django-admin startproject myproject
Salin selepas log masuk

Pergi ke dalam direktori projek dan buat aplikasi yang dipanggil "api".

$ cd myproject
$ python manage.py startapp api
Salin selepas log masuk
  1. Mengkonfigurasi projek dan aplikasi
    Dalam fail settings.py projek, kita perlu menambah aplikasi "rest_framework" dan "api" pada senarai INSTALLED_APPS.
INSTALLED_APPS = [
    ...
    'rest_framework',
    'api',
]
Salin selepas log masuk

Anda juga perlu mengkonfigurasi fail urls.py projek untuk memajukan laluan permintaan ke aplikasi API kami.

from django.urls import include, path

urlpatterns = [
    ...
    path('api/', include('api.urls')),
]
Salin selepas log masuk
  1. Mencipta model dan penyeri bersiri
    Dalam api aplikasi kami, kami perlu mentakrifkan kelas model terlebih dahulu untuk mewakili sumber dalam API kami. Mengambil artikel sebagai contoh, kita boleh menentukan model bernama "Article" dalam fail models.py.
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)
Salin selepas log masuk

Seterusnya, kita perlu mencipta fail yang dipanggil serializers.py dalam direktori api dan mentakrifkan serializer yang dipanggil "ArticleSerializer" untuk menukar contoh model kepada 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']
Salin selepas log masuk
  1. Buat paparan
    Buat fail yang dipanggil views.py dalam direktori api dan tambahkan paparan kelas yang dipanggil ArticleList untuk mengendalikan permintaan GET dan POST.
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
Salin selepas log masuk

Kami juga boleh membuat paparan kelas yang dipanggil ArticleDetail untuk mengendalikan permintaan GET, PUT dan DELETE untuk satu artikel.

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
Salin selepas log masuk
  1. Konfigurasikan URL
    Buat fail bernama urls.py dalam direktori api dan tambah kod berikut untuk mengkonfigurasi laluan.
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'),
]
Salin selepas log masuk
  1. Mulakan perkhidmatan
    Kini kami boleh menjalankan pelayan pembangunan dan menguji API kami.
$ python manage.py runserver
Salin selepas log masuk
  1. Menguji API
    Menggunakan alatan seperti Posmen atau curl, dsb., anda boleh menghantar permintaan HTTP untuk menguji API. Berikut ialah beberapa contoh permintaan API biasa.
  • Dapatkan semua artikel (PERMINTAAN GET):

    GET http://localhost:8000/api/articles/
    Salin selepas log masuk
  • Dapatkan satu artikel (permintaan GET):

    GET http://localhost:8000/api/articles/1/
    Salin selepas log masuk
  • Buat artikel baharu (permintaan POST):

    🜎rreee ) :
  • POST http://localhost:8000/api/articles/
    Content-Type: application/json
    
    {
      "title": "Hello",
      "content": "This is a test article."
    }
    Salin selepas log masuk
  • Padamkan artikel (DELETE request) :
  • PUT http://localhost:8000/api/articles/1/
    Content-Type: application/json
    
    {
      "title": "Hello World",
      "content": "This is an updated test article."
    }
    Salin selepas log masuk
  • Ringkasan:
  • Dalam artikel ini, kami memperkenalkan cara menggunakan rangka kerja Django untuk membina API RESTful. Dengan mencipta model dan penyeri bersiri, mentakrifkan paparan dan konfigurasi URL, kami boleh membina API berfungsi sepenuhnya dan mengujinya dengan cepat. Ini menyediakan asas yang baik untuk kami membina aplikasi web moden dan menyediakan perkhidmatan berskala. Menggunakan rangka kerja Django, kami boleh mengendalikan keperluan API biasa dengan mudah seperti mendapatkan, mencipta, mengemas kini dan memadamkan sumber.

    (bilangan perkataan: 1063)

    Atas ialah kandungan terperinci Gunakan rangka kerja Django untuk membina API RESTful. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Label berkaitan:
sumber:php.cn
Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan