|  |      1cherryas      2023-09-18 10:46:14 +08:00 建议不用想歪了,显然是发出的请求不一样。(仅代表我个人观点) | 
|  |      2dream4ever      2023-09-18 10:53:51 +08:00 一切的诡异最后都会有真实的原因在背后,就你这个情况而言,后端数据有没有可能是其他人修改了?或者是哪里的代码写错了?计算机不会出现灵异事件,绝大部分都是人的原因。 | 
|      3caiqichang      2023-09-18 11:01:23 +08:00 抓包对比一下请求头 | 
|      4NessajCN      2023-09-18 11:02:30 +08:00 没看懂啥叫「直接调用 A 接口」 建议你把两种方式的具体操作方法或代码 po 上来 | 
|  |      5juzisang      2023-09-18 11:14:43 +08:00 nodejs 不至于这么点东西都能搞错,建议好好排查下其它问题... | 
|  |      6dreasky      2023-09-18 11:18:04 +08:00 你的 res 能不要写和外面一样的吗 | 
|      7aikilan      2023-09-18 11:23:08 +08:00 这种情况跟 NODE 没啥关系,直接看看两次请求的 body 有啥区别,如果是内部的接口聚合,不如直接找对于的开发问问有什么需要注意的,或者直接让对方给你断点也许啊 | 
|  |      8pota      2023-09-18 11:26:49 +08:00 先确定请求头和请求内容一致吧。肯定是有不一样的地方 | 
|      9winnerczwx      2023-09-18 11:37:45 +08:00 最诡异的地方不应该是你两次请求参数不同得到了不同的返回值, 而你却觉得这很诡异还发了一贴...? | 
|  |      10Belmode      2023-09-18 11:38:55 +08:00 这个接口里,两个 fetch 方法都是异步的,当这个路由的 Handler 方法返回,fetch A 或者 fetch B 总有一个先调用了 resovle ,第二个还没有调用完成,express 直接把 response 直接响应了。 显然,你这个路由 handler 里最先处理的是 第二个 fetch 方法,获取的 B 数据 | 
|  |      11Belmode      2023-09-18 11:40:11 +08:00 解决办法,用 Promise.all 包裹,或者把两个 fetch 用 then 串联起来。 | 
|      12TabGre      2023-09-18 11:41:43 +08:00 via iPhone 总想搞个大新闻 | 
|  |      13lavvrence      2023-09-18 11:51:13 +08:00 via iPhone  1 基于你的写法我感觉你对 Node.js 不是很熟悉。 常量最好用 const 申明,现在 commonjs 已经逐渐推出历史舞台,所以还是尽快迁到 ESM ,另外请使用 async/await 来处理 Promise 吧,起码可以直观看出代码的执行顺序…… | 
|  |      14slowgen      2023-09-18 12:56:16 +08:00 via Android 基础不牢看什么都是魔法,上抓包数据 | 
|  |      15royalknight      2023-09-18 13:27:52 +08:00 应该是接口的问题,发出来让大伙压力测试下 | 
|  |      16unt OP @royalknight #15 我初步查下来是接口并发有问题。没心气神了,不管了,自己不测试的后端是真菜啊 | 
|      17M003      2023-09-18 15:50:56 +08:00 如果参数一样. 你先确认出来 打印出来是 A,还是 B 的. 建议你在 log 中写死 'A'/'B' ==== 你 A,B 是并发请求; 并不是单步请求,处理完 A,再请求 B. 要不就并发 用 `Promise.all` 要不用 await 单步查看一下,每一步返回什么信息. | 
|  |      18unt OP @M003 #17 这些肯定都知道的呀,所以才说诡异。。这两个请求压根就没请求参数,所以上面说请求参数的我全都忽略了。 是压力并发问题,这接口不是查数据库,所以比较特殊 | 
|  |      19amlee      2023-09-18 16:22:17 +08:00 哈哈,node 里面的东西默认都是异步非阻塞,随便搞个啥东西并发就出来了。 估计你们后端水,后端自己调一下接口,没问题就放那了,压根没考虑并发的事 | 
|      20M003      2023-09-18 16:26:50 +08:00 @unt 排除参数问题, 可能是执行顺序问题. 你可以在最后 console.log 中,打印出接口地址. 你的代码是并行执行了 A 和 B, 如果 B 先执行完,会先打印出来,  现在要看看是 B 先执行完,还是 A 先执行完.  ==== 如果 B 先执行完,先返回数据,并打印出来. 也不是问题. 因为就是这么设计的. 你可以用 async/await 来处理执行顺序. | 
|      21mark2025      2023-09-18 17:14:14 +08:00 接口实现没控制好(并发下的)状态(session, token 等等)吧 | 
|  |      22jiangzm      2023-09-18 23:00:53 +08:00 你应该把抓包的原始请求对比下, 另外 A 接口也要贴出来。 不然让大家陪你猜谜语呢??? | 
|  |      23liuwb      2023-09-19 09:40:34 +08:00 你这所有的响应都用 res 表示,你确定没问题? | 
|      24webszy      2023-09-19 14:40:59 +08:00 via Android 建议重学一下 JS 里的 promise ,你那样写能对吗 |