사용자 도구

사이트 도구


python:django:graphene

Graphene

Graphene-Django는 Django 프로젝트에 GraphQL 기능을 쉽게 추가할 수 있는 몇 가지 추가 추상화를 제공합니다.

graphene-django

Install

pip install graphene-django

INSTALLED_APPS에 추가

setting.py
INSTALLED_APPS = [
    ...
    "django.contrib.staticfiles", # Required for GraphiQL
    "graphene_django"
]

URL추가

urls.py
from django.urls import path
from graphene_django.views import GraphQLView
 
urlpatterns = [
    # ...
    path("graphql", GraphQLView.as_view(graphiql=True)),
]

(Change graphiql=True to graphiql=False if you do not want to use the GraphiQL API browser.)

schema위치를 지정

settings.py
GRAPHENE = {
    "SCHEMA": "django_root.schema.schema"
}

path.schema.schema는 Django프로젝트에서 Schema오브젝트의 위치이다. 기존 schema.py는:

schema.py
import graphene
 
class Query(graphene.ObjectType):
    hello = graphene.String(default_value="Hi!")
 
schema = graphene.Schema(query=Query)

CSRF exempt

Django 앱에서 CSRF 보호 를 활성화 했다면 API 클라이언트가 graphql엔드포인트에 POST하는 것을 방지한다는 것을 알게 될 것입니다 . API 클라이언트를 업데이트하여 각 요청과 함께 CSRF 토큰을 전달할 수 있습니다(Django 문서에는 이를 수행하는 방법에 대한 가이드가 있습니다: https://docs.djangoproject.com/en/3.0/ref/csrf/#ajax ). 당신은 포장하여 CSRF 보호에서 Graphql 엔드 포인트를 면제 할 수있다 GraphQLView로 csrf_exempt 장식 :

urls.py
from django.urls import path
from django.views.decorators.csrf import csrf_exempt
 
from graphene_django.views import GraphQLView
 
urlpatterns = [
    # ...
    path("graphql", csrf_exempt(GraphQLView.as_view(graphiql=True))),
]
python/django/graphene.txt · 마지막으로 수정됨: 2025/04/15 10:05 저자 127.0.0.1