javascript - 在同一 Fetch POST API 调用中返回 JSON

标签 javascript node.js mongodb react-native fetch-api

我目前有一个基于 Node.js Express 框架构建的 Web 应用程序。

我现在正在构建一个需要执行用户登录的 React Native 应用程序。为此,我创建了一个 mongo-helpers.js 文件,该文件将简单地执行对 localhost:3000/api 的 api 调用并返回 JSON。到目前为止,我在进行 GET 调用和接收数据时没有遇到任何问题,但是这是我的问题以及我想要做的事情:

目标:按下登录按钮时(在 React Native 应用程序中)对 localhost:3000/api/login 进行 API 调用,传递用户名passwordfetch API POST 请求的 body 中。如果用户已登录,则发回用户的Mongo文档。

问题:虽然我能够发出 API Post 请求并成功登录用户,但我无法使用 res.json(user)< 发回用户的 Mongo 文档

这是我的代码:

Express WEB APP:routes/api/api.js

// POST and login user
router.post('/login', (req, res) => {
  user.findOne({name: req.body.name, password: req.body.password})
    .then((user) => {
      console.log(user);
      res.json(user)
    })
    .catch((error) => res.json(error))
});

React Native 应用程序:mongo-helpers.js

// Returns a promise
//  if login succeeds then return the user
//  if login fails return error
exports.login = (name, password) => {
  return new Promise(
    (resolve, reject) => {
      fetch(APP_SERVER_URL+'/login', {
        method: 'POST',
        headers: {
          'Accept': 'application/json',
          'Content-Type': 'application/json'
        },
        body: JSON.stringify({name, password})
      }).then((response) => {
        console.log('Response', response);
      }).then((data) => {
        console.log(data); // returns undefined :(
        resolve(data);
      }).catch((error) => {
        console.log('Error', error); // no error is returned
        reject(error);
      })
    }
  )
};

我正在记录响应,下面是它显示的内容。其中没有用户数据

image of response object returned after POST request

最佳答案

你需要调用 json 函数,它会返回一个 Promise,尝试一下:

fetch(APP_SERVER_URL+'/login', {
            method: 'POST',
            headers: {
              'Accept': 'application/json',
              'Content-Type': 'application/json'
            },
            body: JSON.stringify({name, password})
          }).then((response) => {
            response.json().then((data) => {
               console.log(data)
          });
          }).catch((error) => {
            console.log('Error', error); // no error is returned
            reject(error);
          })
        }

https://developer.mozilla.org/en-US/docs/Web/API/Body/json

关于javascript - 在同一 Fetch POST API 调用中返回 JSON,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/43769511/

相关文章:

javascript - 子对象调用兄弟对象的方法

mongodb - MongoDB 中的 $elemMatch 查询

javascript - Mongoose 索引

node.js - Order by 自定义模型中定义的字段属于多个关联。同时选择几个字段

javascript - create-react-app 新项目命令行对我不起作用

javascript - 使用ng-flow取文件时如何将文件发送到node.js和后端

linux - 在 RedHat 上安装 MongoDB 时出现错误

javascript - 让history.back()忽略确认表单重新提交

javascript - IE JavaScript 提示

javascript - 如何从http切换到https客户端