====== 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))), ]