====== Graphene ======
* [[https://docs.graphene-python.org/projects/django/en/latest/|Graphene-Django]]
Graphene-Django는 Django 프로젝트에 GraphQL 기능을 쉽게 추가할 수 있는 몇 가지 추가 추상화를 제공합니다.
===== graphene-django =====
==== Install ====
pip install graphene-django
INSTALLED_APPS에 추가
INSTALLED_APPS = [
...
"django.contrib.staticfiles", # Required for GraphiQL
"graphene_django"
]
URL추가
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위치를 지정
GRAPHENE = {
"SCHEMA": "django_root.schema.schema"
}
**path.schema.schema**는 Django프로젝트에서 Schema오브젝트의 위치이다.
기존 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 장식 :
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))),
]