Не удается включить CORS / разрешить заголовки в среде Python graphql - ariadne
Когда я подключаюсь из своего внешнего приложения React к моему бэкэнду graphql, созданному в python Ariadne, я получаю эту ошибку.
Реагировать на запрос
const uri = 'http://localhost:8000/'
const link = new HttpLink({
uri,
const client = new ApolloClient({
link,
cache: new InMemoryCache(),
});
});
client.query({
query: gql`
{
"myquery"
}
}
`
}).then(result => console.log(result));
Конфигурация Ариадны
from ariadne import make_executable_schema, load_schema_from_path
from ariadne.asgi import GraphQL
type_defs = load_schema_from_path(SCHEMA_FILE)
schema = make_executable_schema(type_defs, *types)
app = GraphQL(schema, debug=True)
Я получаю эту ошибку в консоли Chrome
Access to fetch at 'http://localhost:8000/' from origin 'http://localhost:3000' has been blocked by CORS policy: Response to preflight request doesn't pass access control check: No 'Access-Control-Allow-Origin' header is present on the requested resource. If an opaque response serves your needs, set the request's mode to 'no-cors' to fetch the resource with CORS disabled.
POST http://localhost:8000/ net::ERR_FAILED
Также увикорн распечатывает:
INFO: 127.0.0.1:59910 - "OPTIONS / HTTP/1.1" 405 Method Not Allowed
Как включить CORS?
1 ответ
Решение
Аридна не поддерживает CORS. Вам нужно обернуть сервер Ariadne звездочкой, а затем разрешить источники в CORSMiddleware
from starlette.middleware.cors import CORSMiddleware
(...)
app = CORSMiddleware(GraphQL(schema, debug=True), allow_origins=['*'], allow_methods=("GET", "POST", "OPTIONS"))