Nodejs 写简单接口发现一件诡异的事,求解答



用 node 写了一个接口,这个接口里会调用很多现成的 api 接口,然后将这些接口返回的数据重新组合规整一并返回。

测试过程中发现 A 接口返回的数据居然和直接调用 A 接口不一样。。

A 接口写在 app.get 里返回:
{data:[{bit:‘35’}],code:0}

直接调用 A 接口返回:
{data:[{bit:‘0’}],code:0}


这究竟是为什么。。。
Nodejs 写简单接口发现一件诡异的事,求解答


25 回复

建议不用想歪了,显然是发出的请求不一样。(仅代表我个人观点)


一切的诡异最后都会有真实的原因在背后,就你这个情况而言,后端数据有没有可能是其他人修改了?或者是哪里的代码写错了?计算机不会出现灵异事件,绝大部分都是人的原因。

抓包对比一下请求头

没看懂啥叫「直接调用 A 接口」
建议你把两种方式的具体操作方法或代码 po 上来

nodejs 不至于这么点东西都能搞错,建议好好排查下其它问题…

你的 res 能不要写和外面一样的吗

这种情况跟 NODE 没啥关系,直接看看两次请求的 body 有啥区别,如果是内部的接口聚合,不如直接找对于的开发问问有什么需要注意的,或者直接让对方给你断点也许啊

先确定请求头和请求内容一致吧。肯定是有不一样的地方

最诡异的地方不应该是你两次请求参数不同得到了不同的返回值, 而你却觉得这很诡异还发了一贴…?

这个接口里,两个 fetch 方法都是异步的,当这个路由的 Handler 方法返回,fetch A 或者 fetch B 总有一个先调用了 resovle ,第二个还没有调用完成,express 直接把 response 直接响应了。

显然,你这个路由 handler 里最先处理的是 第二个 fetch 方法,获取的 B 数据

解决办法,用 Promise.all 包裹,或者把两个 fetch 用 then 串联起来。

总想搞个大新闻

基于你的写法我感觉你对 Node.js 不是很熟悉。
常量最好用 const 申明,现在 commonjs 已经逐渐推出历史舞台,所以还是尽快迁到 ESM ,另外请使用 async/await 来处理 Promise 吧,起码可以直观看出代码的执行顺序……

基础不牢看什么都是魔法,上抓包数据

应该是接口的问题,发出来让大伙压力测试下

#15 我初步查下来是接口并发有问题。没心气神了,不管了,自己不测试的后端是真菜啊

如果参数一样. 你先确认出来 打印出来是 A,还是 B 的. 建议你在 log 中写死 ‘A’/‘B’
====
你 A,B 是并发请求; 并不是单步请求,处理完 A,再请求 B.

要不就并发 用 Promise.all 要不用 await 单步查看一下,每一步返回什么信息.

#17 这些肯定都知道的呀,所以才说诡异。。这两个请求压根就没请求参数,所以上面说请求参数的我全都忽略了。 是压力并发问题,这接口不是查数据库,所以比较特殊

哈哈,node 里面的东西默认都是异步非阻塞,随便搞个啥东西并发就出来了。

估计你们后端水,后端自己调一下接口,没问题就放那了,压根没考虑并发的事

排除参数问题, 可能是执行顺序问题. 你可以在最后 console.log 中,打印出接口地址. 你的代码是并行执行了 A 和 B, 如果 B 先执行完,会先打印出来, 现在要看看是 B 先执行完,还是 A 先执行完.

====

如果 B 先执行完,先返回数据,并打印出来. 也不是问题. 因为就是这么设计的. 你可以用 async/await 来处理执行顺序.

接口实现没控制好(并发下的)状态(session, token 等等)吧

你应该把抓包的原始请求对比下, 另外 A 接口也要贴出来。 不然让大家陪你猜谜语呢???

你这所有的响应都用 res 表示,你确定没问题?

建议重学一下 JS 里的 promise ,你那样写能对吗

在Node.js中写接口时遇到诡异的问题确实可能让人困惑。为了更好地帮助你定位问题,我可以提供一些常见的排查步骤和示例代码,希望能启发你找到问题的根源。

首先,确保你的Node.js环境是健康的,并且所有依赖都已正确安装。接下来,我们可以写一个简单的Express接口来排查问题:

const express = require('express');
const app = express();
const port = 3000;

app.get('/test', (req, res) => {
  try {
    // 模拟一些处理逻辑
    let data = { message: 'Hello, world!' };
    res.json(data);
  } catch (error) {
    console.error('Error handling request:', error);
    res.status(500).json({ error: 'Internal Server Error' });
  }
});

app.listen(port, () => {
  console.log(`Server running at http://localhost:${port}/`);
});
  1. 检查控制台输出:运行代码后,查看控制台是否有错误信息。
  2. 网络请求:使用工具(如Postman或curl)访问http://localhost:3000/test,查看响应。
  3. 调试代码:在IDE中设置断点,逐步执行代码,观察变量变化。
  4. 日志记录:增加日志输出,记录关键步骤和变量值。

如果上述步骤未能解决问题,请详细描述你遇到的“诡异”现象,包括错误消息、请求和响应的具体内容,以便进一步分析。此外,检查Node.js版本和Express库的版本是否兼容,有时候版本不匹配也会导致问题。

回到顶部