如何将React应用程序与Shopify应用程序连接?

如何将React应用程序与Shopify应用程序连接?,shopify,polaris,Shopify,Polaris,我是shopify应用程序开发网的新手,偶然发现了shopify为一致的用户界面开发提供的Polaris react库。我的想法是构建一个Node.js Express应用程序来验证和安装应用程序,处理数据,并为商店管理员的用户界面创建一个react应用程序 我在网上搜索,但找不到标准或推荐的方式将react应用程序连接到shopify应用程序 我能想到的是,当一个商店管理员从应用程序部分选择应用程序并成功通过如下身份验证时,从节点应用程序重定向到React应用程序 app.get('/shop

我是shopify应用程序开发网的新手,偶然发现了shopify为一致的用户界面开发提供的Polaris react库。我的想法是构建一个Node.js Express应用程序来验证和安装应用程序,处理数据,并为商店管理员的用户界面创建一个react应用程序

我在网上搜索,但找不到标准或推荐的方式将react应用程序连接到shopify应用程序

我能想到的是,当一个商店管理员从应用程序部分选择应用程序并成功通过如下身份验证时,从节点应用程序重定向到React应用程序

app.get('/shopify/callback', (req, res) => {
  const { shop, hmac, code, state } = req.query;
  const stateCookie = cookie.parse(req.headers.cookie).state;

  if (state !== stateCookie) {
    return res.status(403).send('Request origin cannot be verified');
  }

  if (shop && hmac && code) {
    const map = Object.assign({}, req.query);
    delete map['signature'];
    delete map['hmac'];
    const message = querystring.stringify(map);
    const generatedHash = crypto
      .createHmac('sha256', apiSecret)
      .update(message)
      .digest('hex');

    if (generatedHash !== hmac) {
      return res.status(400).send('HMAC validation failed');
    }

    const accessTokenRequestUrl = 'https://' + shop + '/admin/oauth/access_token';
    const accessTokenPayload = {
      client_id: apiKey,
      client_secret: apiSecret,
      code,
    };

    request.post(accessTokenRequestUrl, { json: accessTokenPayload })
      .then((accessTokenResponse) => {
        const accessToken = accessTokenResponse.access_token;

        const shopRequestUrl = 'https://' + shop + '/admin/shop.json';
        const shopRequestHeaders = {
          'X-Shopify-Access-Token': accessToken,
        };
        res.redirect([URL to the react app built with Polaris]);
      })
      .catch((error) => {
        res.status(error.statusCode).send(error.error.error_description);
      });

  } else {
    res.status(400).send('Required parameters missing');
  }
});

我已经做到了,但我不确定这是否是推荐的方法。

它们是三种不同的东西:Node.JS、React和Polaris,您可以选择其中任何一种。Polaris是一个库,如果您想使用它,只需运行
warn add@shopify Polaris
并阅读它的文档即可。就这些


不管有没有Polaris,你都可以创建一个Shopify应用程序,有不同的堆栈。

它们是三种不同的东西:Node.JS、React和Polaris,你可以选择其中任何一种。Polaris是一个库,如果您想使用它,只需运行
warn add@shopify Polaris
并阅读它的文档即可。就这些


不管有没有Polaris,你仍然可以创建一个Shopify应用程序,有不同的堆栈。

是的,但我想让Shopify插件在节点后端,用于访问商店管理api和处理数据,以及在管理应用程序页面上与Polaris library for UI作出反应。现在,当shop admin选择我的应用程序时,我将从节点服务器重定向到react应用程序。我问这是不是一个好的实践,或者是SubTiice推荐的一个标准的应用程序,用于为应用程序的后端提供UI和节点的单独的反应应用程序?我认为Actudio/PuliSIS和NodeJS是构建JavaSudio应用程序(单个应用程序)的最好方法,如果你是JS开发者的话。事实上,我非常喜欢北极星,因为我不需要自己去模仿Shopify用户界面。我在这里创建了一个简单的Shopify应用程序,当我学习如何构建Shopify应用程序时,我继续使用我在问题中发布的方式。谢谢你的建议和答案。我会接受这个回答是的,但我想要的是在节点中有shopify插件后端,用于访问商店管理api和处理数据,以及在管理应用程序页面上与Polaris library for UI作出反应。现在,当shop admin选择我的应用程序时,我将从节点服务器重定向到react应用程序。我问这是不是一个好的实践,或者是SubTiice推荐的一个标准的应用程序,用于为应用程序的后端提供UI和节点的单独的反应应用程序?我认为Actudio/PuliSIS和NodeJS是构建JavaSudio应用程序(单个应用程序)的最好方法,如果你是JS开发者的话。事实上,我非常喜欢北极星,因为我不需要自己去模仿Shopify用户界面。我在这里创建了一个简单的Shopify应用程序,当我学习如何构建Shopify应用程序时,我继续使用我在问题中发布的方式。谢谢你的建议和答案。我接受这个答案