我一直在尝试从express连接到mongodb,但似乎无法克服以下错误 POST http:// localhost:8080 /已提交404(未找到)
我还尝试将app.post函数放置在索引路由器下,然后错误变为500 Internal Server Error。
index.hbs
<h1>{{title}}</h1>
<input type="text" name="username" id="username" placeholder="Username">
<button id="submit">Convert</button>
<div id="map"></div>
<div id="info"></div>
<script src="javascripts/client.js"></script>
app.js
var createError = require('http-errors');
var express = require('express');
const mongodb = require("mongodb");
var path = require('path');
var cookieParser = require('cookie-parser');
var logger = require('morgan');
var indexRouter = require('./routes/index');
var usersRouter = require('./routes/users');
var app = express();
// view engine setup
app.set('views', path.join(__dirname, 'views'));
app.set('view engine', 'hbs');
app.use(logger('dev'));
app.use(express.json());
app.use(express.urlencoded({ extended: false }));
app.use(cookieParser());
app.use(express.static(path.join(__dirname, 'public')));
app.use('/', indexRouter);
app.use('/users', usersRouter);
app.listen(8080, () => {
console.log('listening on 8080');
});
let db;
const uri = "mongodb+srv://gio:<password>@<cluster>/db?retryWrites=true&w=majority";
const client = mongodb.MongoClient;
client.connect(uri, (err, client) => {
if(err) {
return console.log(err);
}
db = client.db('db');
});
// catch 404 and forward to error handler
app.use(function(req, res, next) {
next(createError(404));
});
// error handler
app.use(function(err, req, res, next) {
// set locals, only providing error in development
res.locals.message = err.message;
res.locals.error = req.app.get('env') === 'development' ? err : {};
// render the error page
res.status(err.status || 500);
res.render('error');
});
module.exports = app;
app.post('/submitted', (req, res) => {
if (err) {
return console.log(err);
}
let validUsers = db.collection('users').find({
currentLocation: {$ne: null}
});
console.log(validUsers.currentLocation);
});
client.js
const submit = document.getElementById('submit');
submit.addEventListener('click', function(e) {
console.log('test');
fetch('submitted', {method: 'POST'})
.then(function(response) {
if (response.ok) {
console.log('success');
return;
}
throw new Error('Request failed');
})
.catch(function(error) {
console.log(error);
});
})
这是index.js文件,我在其中将POST函数用作router.post 我也在下面更改了app.js。
index.js
var express = require('express');
const mongodb = require("mongodb");
var router = express.Router();
let db;
const uri = "mongodb+srv://gio:<password>@<cluster>/db?retryWrites=true&w=majority";
const client = mongodb.MongoClient;
client.connect(uri, (err, client) => {
if(err) {
return console.log(err);
}
db = client.db('db');
});
/* GET home page. */
router.get('/', function(req, res, next) {
res.render('index', { title: 'Converter' });
});
router.post('/submitted', (req, res) => {
if (err) {
return console.log(err);
}
let validUsers = db.collection('users').find({
currentLocation: {$ne: null}
});
console.log(validUsers.currentLocation);
});
module.exports = router;
app.js
var createError = require('http-errors');
var express = require('express');
const mongodb = require("mongodb");
var path = require('path');
var cookieParser = require('cookie-parser');
var logger = require('morgan');
var indexRouter = require('./routes/index');
var usersRouter = require('./routes/users');
var app = express();
// view engine setup
app.set('views', path.join(__dirname, 'views'));
app.set('view engine', 'hbs');
app.use(logger('dev'));
app.use(express.json());
app.use(express.urlencoded({ extended: false }));
app.use(cookieParser());
app.use(express.static(path.join(__dirname, 'public')));
app.use('/', indexRouter);
app.use('/submitted', indexRouter)
app.use('/users', usersRouter);
app.listen(8080, () => {
console.log('listening on 8080');
});
// catch 404 and forward to error handler
app.use(function(req, res, next) {
next(createError(404));
});
// error handler
app.use(function(err, req, res, next) {
// set locals, only providing error in development
res.locals.message = err.message;
res.locals.error = req.app.get('env') === 'development' ? err : {};
// render the error page
res.status(err.status || 500);
res.render('error');
});
module.exports = app;
我应该注意,对具有占位符的uri字符串所做的更改仅用于stackoverflow,所以这不是错误(我认为)。
答案 0 :(得分:0)
此行会引起问题。
app.use('/submitted', indexRouter); // remove this line
此行说是否/已提交路由,请检查indexRouter。但是你有
router.post('/submitted', (req, res) => {
if (err) {
return console.log(err);
}
let validUsers = db.collection('users').find({
currentLocation: {$ne: null}
});
console.log(validUsers.currentLocation);
});
因此,您需要/ submitted / submitted才能访问它。
删除此行,它应该可以工作。
定义方式,您必须使用以下名称进行调用:http:// localhost:8080 / submitted / submitted