首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >除了使用cookie通过express和react将请求-响应从后端传递到前端之外,还有其他解决方案吗?

除了使用cookie通过express和react将请求-响应从后端传递到前端之外,还有其他解决方案吗?
EN

Stack Overflow用户
提问于 2019-10-05 06:02:13
回答 1查看 23关注 0票数 0

我有下面的Google Analytics API请求,我在Google Auth进程之后运行。到目前为止,我发现将响应传递给前端的唯一方法是将响应存储在cookie中。然后我就可以很容易地用react阅读它了。然而,我真的不喜欢这个选项。我的选择是什么?否则我如何传递响应呢?

代码语言:javascript
复制
   router.get(
        "/auth/google/callback",
        passport.authenticate("google", { failureRedirect: "/error", session: false }),
        function(req, res) {
            var token = req.user.token;
        request('https://www.googleapis.com/analytics/v3/management/accounts?access_token=' + token,  
    function (error, response, body) {
      console.log(body)
      console.log(response)
              let views = []
       JSON.parse(body).items.forEach(view => {
                views.push({
                  name: view.webPropertyId + ' - ' + view.name + ' (' + view.websiteUrl + ')'
                })
              })
    res.cookie("data", views); 
    res.json(views)
    });
        }
    );
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2019-10-05 06:12:39

在前端,使用fetch之类的东西调用后端,然后在JSON中解析响应。它可能看起来像这样:

代码语言:javascript
复制
fetch('/auth/google/callback',
  { 
   method: 'GET',
   credentials: 'same-origin'
  })
.then(response => response.json());

在后端,只需使用res.send(views),其中视图是一个对象。

您可能需要为auth添加额外的头(就像您在api调用中查找令牌一样),但这应该只是将其添加到options对象中的问题。

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/58243610

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档