问题描述
我有一个 GET 请求,我试图通过 ID 在我的数据库中查找电影。我在 Postman 中不断收到 404 错误,但是当我记录响应时,我得到了我需要的一切。我现在一直在兜圈子,所以我确定我只是错过了一些小事,但我不知道我在做什么,正在抛出 404。
这是在我的 App.js 中:
app.use('/myMovies',MovieRouter);
MovieRouter.js:
movieRouter
.route('/:movie_id')
.all(requireAuth)
.all((req,res,next) => {
const db = req.app.get('db')
MovieService.getById(db,req.params.movie_id)
.then(movie => {
if(!movie) { // this runs fine
return res.status(404).json({ error: `Movie doesn't exist`})
}
console.log('line 61: ',movie) // returns: line 61: { id: 867,title: 'Sliver',watched: false,user_id: 2 }
res.movie = movie
console.log('line 63: ',res.movie) // returns: line 63: { id: 867,user_id: 2 }
next()
return movie;
})
.catch(next)
})
MovieService.js:
const MovieService = {
getById(db,id) {
return db.from('your_movie_list').select(
'your_movie_list.id','your_movie_list.title','your_movie_list.watched','your_movie_list.user_id',)
.where('your_movie_list.id',id).first()
},}
解决方法
如果从数据库中找到电影,则需要将响应发送给客户端。
替换
await using var client = new ServiceBusClient("<connectionstring>");
ServiceBusReceiver receiver = client.CreateReceiver("<queuename>");
ServiceBusReceivedMessage receivedMessage = await receiver.ReceiveMessageAsync();
string body = receivedMessage.Body.ToString();
Console.WriteLine(body); //prints {"title":"hello"}
作者:
console.log('line 61: ',movie) // returns: line 61: { id: 867,title: 'Sliver',watched: false,user_id: 2 }
res.movie = movie
console.log('line 63: ',res.movie) // returns: line 63: { id: 867,user_id: 2 }
next()
return movie;