javascript - 从服务器向客户端获取/获取数据时出现问题。 (客户端向服务器发送数据成功)

标签 javascript node.js json api server

我正在为 Udacity 前端开发人员计划做一个项目。目的是使用API​​、node.js和webpack(构建工具)。在我的网站中,我有一个表单,您应该在其中输入一篇文章的 url,客户端会将该 url 发送到服务器,然后服务器会将其发送到 Aylien API,该 API 使用 AI 来分析文本并返回文本所属的类别等。

因此,我使用 npm run build-prod 在终端中构建项目,然后运行服务器并启动网站。我输入随机王牌文章的网址,我可以在服务器终端中看到该网址成功从客户端发送到服务器(我使用console.log来控制它),然后也发送到外部API 成功并返回数据(哪个类别等),但是,然后我想将该信息/数据发送给客户端,但这就是我无法完成的地方。我尝试修复它,但不明白为什么我没有将数据发送到客户端,并且在 Google Chrome 中使用检查时没有错误。

你们能帮帮我吗?欣赏它! 下面的代码来自服务器 js 文件和客户端 js 文件。

编辑:以下代码的最新更新: 编辑2:问题现已解决。雅各布给了我很多帮助。问题出在我使用表单,而不是使用 PreventDefault。使用简单的 e.preventDefault 有助于解决这个问题。

服务器js文件:

    app.post('/post', (req, res) => {
    console.log('I got a request.')
    const data = req.body;
    console.log(data);
    textapi.classify({
        url: data.text
    }, function(error, response) {
        if (error === null) {
            console.log(response);
            res.json(response);
            res.end();
        } else {
            console.log('This is not a valid text or article to evaluate. Try again.')
        }
    });
});

客户端js文件:

    async function postData (url, data) {
    const options = {
        method: 'POST',
        headers: {
            'Content-Type': 'application/json'
        },
        body: JSON.stringify(data)
    };
    const response = await fetch(url, options);
    const json = await response.json();
    console.log(json);
}

formBox.addEventListener('submit', () => {
    data.text = document.getElementById('textBox').value;
    postData('/post', data);
});

最佳答案

大多数 JavaScript 回调(包括用于 textapi.classify 的回调)都是异步调用的。异步代码完成后您想要发生的任何事情都必须进入该回调。

app.post('/post', (req, res) => {
  const data = req.body;
  textapi.classify({
    url: data.text
  }, function(error, response) {
    if (error === null) {
      res.end(response);
    } else {
      res.status(400).end('This is not a valid text or article to evaluate. Try again.');
    }
  });
});

请注意,我还将 res.send 更改为 res.end,它既发送一 block 数据又结束响应。如果您不这样做,那么 Node 会认为您尚未将 block 发送回客户端。

如果你想让你的代码减少回调的嵌套,你可以使用异步函数(Promises)。对于不返回 Promises 的 API,您可以使用 require('util').promisify 来包装它们。以下是使用异步函数方法的方法:

const { promisify } = require('util');

const classifyText = promisify(textapi.classify.bind(textapi));

app.post('/post', async (req, res) => {
  try {
    const response = await textapi.classify({ url: req.body.text });
    res.end(response);
  } catch (error) {
    console.error(error);
    res
      .status(400)
      .end('This is not a valid text or article to evaluate. Try again.');
  }
});

请注意,res.sendres.end 用于发送文本或字节(缓冲区)。如果您想发送 JSON,express 会为您提供一个 res.json(...) ,它类似于 res.end(JSON.stringify(...)).

关于javascript - 从服务器向客户端获取/获取数据时出现问题。 (客户端向服务器发送数据成功),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/61551506/

相关文章:

JavaScript - 使用 for 循环时子元素会重复

php - 更改 JSON 的 mysql 结果以按键索引

javascript - 如何让按钮在点击时显示内容?

node.js - 使用 mocha 运行时,仍然收到 babel-plugin-syntax-dynamic-import 动态导入的语法错误

node.js - 如何在 Node js 中链接 Angular 2?

Char* 从 char 数组中解析错误

javascript - 使用 requestAnimationFrame 实现稳定的帧率?

javascript - 向 ko observable 数组项添加属性

javascript - 如何自定义JCoverFlip的大小?

node.js - 在 now.js/socket.io 聊天中增强安全性