이번 글에서는 Rest Framework에 대해 설명하겠습니다. 기술적인 세부 사항에 들어가기 전에 Rest Framework가 무엇인지 잠깐 알아보겠습니다.
Rest Framework는 모바일 애플리케이션, 웹 애플리케이션 및 데스크톱 애플리케이션 모두에 대한 공통 백엔드를 코딩할 수 있는 고급 프레임워크입니다. 예를 들어 모바일 애플리케이션과 웹 애플리케이션 모두에서 Rest Framewok으로 코딩한 백엔드 서버를 사용할 수 있습니다.
Rest Framework를 Angular, React, Vue와 같은 프런트엔드 기술과 함께 사용하여 애플리케이션을 개발할 수 있습니다. Rest Framework는 프로그래밍의 공통 구조로 응답을 제공하므로 이러한 출력을 Angular 또는 React에서 사용할 수 있습니다. 그렇다면 이러한 출력 유형은 무엇입니까? 물론 JSON과 같은 구조입니다. 물론 선택적으로 이러한 출력을 다양한 구조로 프런트엔드 측으로 보낼 수도 있습니다. 이제 코딩으로 넘어갑니다
프로젝트 만들기
1) django-admin startproject 프로젝트 이름
프로젝트를 만들었습니다. 이제 프로젝트를 실행해 보겠습니다.
2) python Manage.py runserver
그럼 데이터베이스에 필요한 테이블을 생성하는 데 필요한 명령을 작성해 보겠습니다.
3) Python Manage.py 마이그레이션
우리가 만든 애플리케이션을 settings.py 파일 아래의 INSTALLED_APPS 디렉터리에 추가하는 것을 잊지 마세요.
모든 것이 괜찮습니다. 이제 나머지 프레임워크에 필요한 단계로 넘어갈 수 있습니다.
컴퓨터에 Rest Framework를 설치하려면 터미널에서 다음 명령을 실행해야 합니다.
1) pip install djangorestframework
예를 들면
INSTALLED_APPS = [
'django.contrib.admin',
'django.contrib.auth',
'django.contrib.contenttypes',
'django.contrib.sessions',
'django.contrib.messages',
'django.contrib.staticfiles',
'rest_framework',
'포스트앱',
]
Rest 프레임워크를 추가했으므로 이제 API 생성을 시작할 수 있습니다. 이를 위해서는 API라는 폴더를 생성하고 우리가 생성한 애플리케이션 폴더에 일부 파일을 생성해야 합니다. 다음 파일을 추가해 보겠습니다.
당신의 프로젝트/
API/
초기화.py
views.py
urls.py
serializers.py
** init.py** 파일을 사용하면 이 폴더가 Python 모듈임을 나타냅니다
views.py ** 파일은 들어오는 요청에 대해 보낼 답변을 제공할 클래스나 함수를 작성하는 파일입니다.
**urls.py 파일은 Django의 구조에서 짐작할 수 있듯이 API URL을 설정하는 파일입니다.
serializers.py 파일은 들어오는 쿼리 세트를 원하는 형식(예: JSON)으로 배치하는 구조를 작성하는 파일입니다. 자세한 내용은 차차 알려드리겠습니다.
먼저 프로젝트의 메인 폴더에 준비된 urls.py 파일로 이동하여 생성한 API 폴더에 따라 URL 경로를 정의해 보겠습니다.
urlpatterns = [
경로('admin/', admin.site.urls),
path("api/post/",include("YOUR_PROJECT.api.urls",namespace="post")),
]
이미 관리자 경로가 있습니다. 또한 api/post라는 새 경로를 추가했습니다. include 메소드를 사용하여 api/post/로 들어오는 요청을 우리가 만든 API 폴더의 URL 파일로 리디렉션했습니다.
이제 우리가 작성한 게시물에 대한 모델을 빠르게 작성해 보겠습니다. YOUR_PROJECT 폴더에 있는 models.py 파일을 찾아보겠습니다.
클래스 PostModel(models.Model):
작성자 = models.ForeignKey(User,on_delete=models.CASCADE)
제목 = models.CharField(max_length=50)
콘텐츠 = models.TextField()
초안 = models.BooleanField(기본값=False)
ModifiedDate = models.DateTimeField(editable=False)
모델을 생성한 후 데이터베이스에 테이블을 생성하기 위해 필요한 코드를 터미널에 작성해 보겠습니다.
pythonmanage.py makemigration
이러한 코드를 사용하여 데이터베이스에 테이블을 만드는 데 필요한 Python 파일을 만들었습니다. 다음 명령을 실행하여 테이블을 생성하겠습니다.
*python Manage.py 마이그레이션 *
이제 우리가 만든 YOUR_PROJECT 디렉터리 아래 api 폴더에 있는 빈 urls.py 파일을 살펴보겠습니다.
django.urls 가져오기 경로에서
.views에서 YourProjectAPIView 가져오기
app_name="포스트"
urlpatterns = [
path("list/",YourProjectAPIView.as_view(),name="your_project"),
]
먼저 app_name=”post”로 애플리케이션 이름을 지정했습니다.
이제 아직 생성하지 않은 뷰를 가져와서 경로에 맞게 사용해 보았습니다. YOUR_PROJECT/api 디렉토리 아래 views.py 파일에 작성한 이름의 뷰를 즉시 생성해 보겠습니다.
먼저, JSON 구조의 요청과 함께 데이터베이스의 모든 게시물을 보내는 뷰를 만들어 보겠습니다.
POSTAPP.models에서 PostModel 가져오기
Rest_framework.generics에서 ListAPIView 가져오기
클래스 PostListAPIView(ListAPIView):
serializer_class = PostSerializer
queryset = PostModel.objects.all()
여기서 우리가 한 일을 설명해 보겠습니다. Rest Framework의 목록 프로세스를 위해 준비된 ListAPIView 클래스를 사용하여 뷰를 만들었습니다. 먼저 queryset 변수를 사용하여 어떤 모델을 반환할지 결정합니다. 그리고 이 모델에서 나오는 데이터, 즉 쿼리 세트를 직렬화할 직렬 변환기 클래스를 지정해야 합니다. 결국 우리는 상대방에게 쿼리셋을 보내지 않을 것이다. 직렬화된 JSON 객체를 보내드립니다. 쿼리 세트를 JSON 개체로 변환하는 구조가 우리가 생성할 직렬 변환기가 됩니다.
지금은 serializer_class 변수에 PostSerializer라는 직렬 변환기를 만들었습니다. 동일한 디렉터리의 serializers.py 파일에 이 직렬 변환기를 생성합니다. 지금 만들어 보겠습니다.
rest_framework 가져오기 직렬 변환기
클래스 YourProjectSerializer(serializers.ModelSerializer):
클래스 메타:
모델 = 포스트모델
fields = ["저자","제목","내용",'초안','수정 날짜']
위 내용은 Django Rest Framework란 무엇인가요?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!