3

看起来我的公司将继续使用来自 Apollo 客户端的持久查询,如下所述:https ://dev-blog.apollodata.com/persisted-graphql-queries-with-apollo-client-119fd7e6bba5

在这篇文章中提到需要对服务器上的中间件做一些事情。我一直找不到任何关于 Graphene-Django 需要改变什么的信息。

任何人都可以提供任何建议吗?

罗伯特

4

2 回答 2

2

持久化查询不是 GraphQL 规范的一部分,因此可以通过多种方式实现。以下是一些您可能希望如何在服务器上执行此操作的示例:

提取查询

在撰写本文时,您可以使用 Relay Modern、Apolo 客户端等提取静态查询。它们都以类似的方式工作,因此我将使用Apollo PersistGraphQL作为示例。在你的构建中,你需要persistgraphql在你的 src 目录上运行命令来提取你的静态查询。此命令的结果将是一个 JSON 文件,其中包含查询、字符串和数字作为值。

{
  "
  { 
    author {
      firstName
      lastName
    }
  }
  ": 9,
  "
  query otherQuery {
    person {
      firstName
      lastName
    }
  }
  ": 10
}

使用提取的查询

从这里,您有几个选择。一旦您的服务器知道所有可能的查询,它就可以为 JSON 文件中提供的值提供接口,也可以将它知道的查询列入白名单。如果您的服务器仅提供值的接口(myserver/api/9myserver/api/10上面的示例中),您需要确保您的客户端应用程序通过使用相同的 JSON 文件将其查询映射到商定的 ID。或者,您可以使用该文件来防止执行意外查询,而无需以任何方式修改客户端。

如何具体设置服务器以使用此 JSON 文件取决于您。有些人会预先执行一组已知查询并将它们放入像 Redis 这样的快速数据存储中。有些人严格使用它来防止未经授权的查询。至于如何使用 Django-Graphene 完成此操作,我知道没有开箱即用的解决方案,但使用像上面那样提取的键/值存储应该为您的团队提供一堆好的选项。

于 2017-07-23T22:13:21.800 回答
0

您可以检查 Graphene Django 的持久查询

https://github.com/flavors/django-graphql-persist

于 2019-02-06T14:25:59.150 回答