1、参考:https://www.shuijingwanwq.com/2022/03/15/6129/ 。Shopify’s GraphQL Admin API 中,不存在一些在线商店的 API。
2、Shopify 后台的在线商店,请求网址: https://xxx.myshopify.com/admin/online-store/admin/api/unversioned/graphql?operation=ThemeIndexSecondaryData 。请求方法: POST 。响应主题列表。如图1
3、在网址:https://shopify.dev/api 中未找到在线商店相关的 GraphQL API。如图2
4、在 /admin/api/2022-01/graphql.json 的文档中搜索:ThemeIndexSecondaryData,未找到(注:这仅是查询的别名,应该基于载荷中的请求参数搜索)。如图3
5、在 Altair GraphQL Client 中,设置请求网址:https://xxx.myshopify.com/admin/online-store/admin/api/unversioned/graphql?operation=ThemeIndexSecondaryData
6、Shopify 后台的在线商店,复制请求载荷中 query 的值,右键 – 复制值。然后再复制 请求载荷中 variables 的值。如图4
7、分别粘贴至 Altair GraphQL Client 的查询与变量中。如图5
8、设置 Headers,Content-Type:application/json,Authorization:Bearer xxxx,xxxx 的值复制自请求标头中的 authorization。如图6
9、响应 Unauthorized,仔细对比请求头中的差异,发现 Altair GraphQL Client 中多出 cookie,决定去除掉。如图7
10、在 Postman 中试验调用,仍然响应 Unauthorized。如图8
11、分析发现由于 authorization 的值,是先请求生成的。复制 Headers,x-csrf-token: oO73nzXt-GNexB7LPmAZnm70wjWB9fKRLMvU。如图9
12、决定在 Altair GraphQL Client 中 请求网址: https://fuyan666.myshopify.com/admin/internal/web/graphql/core?operation=GenerateSessionToken&type=mutation 。请求方法: POST 。设置 Headers,x-csrf-token: oO73nzXt-GNexB7LPmAZnm70wjWB9fKRLMvU。否则响应 CSRF。如图10
13、复制响应的 session ,粘贴至 请求网址:https://xxx.myshopify.com/admin/online-store/admin/api/unversioned/graphql?operation=ThemeIndexSecondaryData 的 Headers 的 Authorization 中。请求响应成功。如图11
14、重载文档响应成功。如图12
原创文章,作者:ItWorker,如若转载,请注明出处:https://blog.ytso.com/250735.html