如何通过我的节点 API 正确路由数据?

How do I properly route data through my Node API?

我有以下文件:

我的路线 - orders_count 路线所在的位置:

routes/index.js

const express = require('express');
const router = express.Router();

const transactionsController = require('../controllers/transactionsController');
const ordersController = require('../controllers/ordersController');
const ordersCountController = require('../controllers/ordersCountController');

router.get('/transactions', transactionsController);
router.get('/orders', ordersController);
router.get('/orders_count', ordersCountController);

module.exports = router;

然后我将我的订单计数控制器放在控制器目录中:

controllers/ordersCountController.js

const ordersCountService = require('../services/ordersCountService');

const ordersCountController = (req, res) => {
    ordersCountService((error, data) => {
        if (error) {
            return res.send({ error });
        }

        res.send({ data })
    });
};

module.exports = ordersCountController;

我的控制器然后调用我的订单计数服务,该服务从另一个 API.

获取数据

services/ordersService.js

const fetch = require('node-fetch');

// connect to api and make initial call
const ordersCountService = (req, res) => {
    const url = ...;

    const settings = { method: 'Get'};

    fetch(url, settings)
        .then(res => {
            if (res.ok) {
                res.json().then((data) => {
                    return data;
                });
            } else {
                throw 'Unable to retrieve data';
            }
        }).catch(error => {
        console.log(error);
    });
}

module.exports = ordersCountService;

我正在尝试 return JSON 响应。我最初使用请求设置它,但查看 NPM 站点时,它似乎已经贬值,所以一直在研究如何使用 node-fetch。

我已经尝试了 'return data' 和 res.send({data}),但都没有解决问题。

我对此还是个新手,所以我可能遗漏了一些非常明显的东西,但我为什么不将 JSON 发送回去,以便它显示在 /api/orders_count 端点?

我一直在想我在我的控制器中搞砸了一些东西,但已经看了很长时间,似乎无法弄清楚。

如有任何帮助,我们将不胜感激,如果有任何我可以补充的内容,请随时提出。

最佳。

  1. 请学习 promises 和 await 语法。生活会更轻松。
  2. 永远不要抛出字符串。总是喜欢一个真正的错误对象,比如:throw new Error('xxx');这样你总会得到一堆。它更容易调试。
  3. 避免回调地狱:http://callbackhell.com/
  4. 您需要决定是要在控制器中还是在服务中捕获错误。两者都不需要做。
  5. 在您调用服务的控制器中:
ordersCountService((error, data) => {

但你是这样声明的:

const ordersCountService = (req, res) => {

不兼容。如果您使用回调样式,它应该看起来像这样:

const ordersCountService = (callback) => {
...
if (error) return callback(error)
...
callback(null, gooddata);

这里是一个将 ordersCountService 函数扁平化为 await 语法的示例,它允许您尝试执行的“return 数据”:

const fetch = require('node-fetch');

// connect to api and make initial call
const ordersCountService = async (req, res) => {
    const url = ...;

    const settings = { method: 'Get'};
    try {
        const res = await fetch(url, settings);
        if (!res.ok) throw new Error('Unable to retrieve data');

        return await res.json();
    } catch(error) {
        console.log(error);
    }
}

module.exports = ordersCountService;

事实上,我更愿意在控制器中处理错误。那么这作为一项服务就足够了

const fetch = require('node-fetch');

// connect to api and make initial call
const ordersCountService = async () => {
    const url = ...;

    const settings = { method: 'Get'};
    const res = await fetch(url, settings);
    if (!res.ok) throw new Error('Unable to retrieve data');

    return await res.json();
}

module.exports = ordersCountService;

然后你可以这样调用这个函数:

try {
  const data = await ordersCountService(req, res);
} catch(err) {
  console.log(err);
}

//or 
ordersCountService(req, res).then((data) => console.log(data)).catch((err) => console.error(err));