简单Node JSjs故障排除 - 从 app.get() 接收 404



我正在尝试部署一个节点.js Heroku 应用程序,该应用程序侦听请求并简单地将编码字符串记录到控制台。注意:我只能以 JSON 格式从我的程序导出数据,这就是我使用 req.body 的原因。


JavaScript

const express = require('express')
const app = express()
app.get('/um', function (req, res) {
  console.log(req.body[message]);
})
app.listen(process.env.PORT || 3000, function () {
  console.log('App listening!')
})

路亚

local httpService = game:GetService('HttpService')
httpService:PostAsync("http://auto-attica.herokuapp.com/um", { "message" = "foo" })

而不是将文本记录到控制台。我在运行Lua的程序和Heroku控制台上都收到错误404。

2017-10-30T00:10:04.826245+00:00 heroku[router]: at=info method=POST path="/um" host=auto-attica.heroku-f35fbe137630 fwd="95.148.67.104" dyno=web.1 connect=1ms service=5ms status=404 bytes=386 protocol=http

和在 Lua 控制台上

00:16:02.074 - HTTP 404 (HTTP/1.1 404 Not Found)
00:16:02.074 - Stack Begin
00:16:02.075 - Script 'ServerScriptService.myOwnVanilla', Line 8
00:16:02.075 - Stack End

非常感谢您的时间

您正在快速路由中定义一个GET请求,但尝试向其发送一个POST请求,这就是您的 Heroku 日志向您显示的内容。

2017-10-30T00:10:04.826245+00:00 heroku[router]: at=info method=POST path="/um" 
                                                                ^^^^

可以尝试设置POST处理程序:

app.post('/um', function (req, res) {
  console.log(req.body[message]);
})

从你上面的代码中,尤其是这行代码 req.body[message],我不知道你是如何得到这条消息的。为什么不在尝试访问该终结点时发送响应。示例如下所示:

const express = require('express')
const app = express();
app.get('/um', function (req, res) {
  res.json({ message: 'Its working' });
});
app.listen(process.env.PORT, function () {
  console.log('App listening!');
});

最新更新