我正在尝试部署一个节点.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!');
});