Node.js NodeJs路由在生产中返回404,但在本地不返回404

Node.js NodeJs路由在生产中返回404,但在本地不返回404,node.js,express,cpanel,Node.js,Express,Cpanel,我正在开发我的第一个NodeJS应用程序。 我在本地环境中试用了我的应用程序,效果很好。所以我决定在我的共享主机上部署它 我有一个路由器的问题,它在生产环境中返回404,但在本地环境中不返回404 我调用的路径:GET/match/getAllMatches 这是我的app.js文件: const createError = require('http-errors'); const express = require('express'); const path = require('

我正在开发我的第一个NodeJS应用程序。 我在本地环境中试用了我的应用程序,效果很好。所以我决定在我的共享主机上部署它

我有一个路由器的问题,它在生产环境中返回404,但在本地环境中不返回404

我调用的路径:GET/match/getAllMatches

这是我的app.js文件:

    const createError = require('http-errors');
const express = require('express');
const path = require('path');
const cookieParser = require('cookie-parser');
const logger = require('morgan');
const sequelize = require('./config/database');
const bodyParser = require('body-parser');

const indexRouter = require('./routes/index');
const usersRouter = require('./routes/users');
const matchRouter = require('./routes/match.js');

const app = express();

// view engine setup
app.set('views', path.join(__dirname, 'views'));
app.set('view engine', 'pug');

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('/match', matchRouter);
app.use('/api/auth', usersRouter);

// 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');
});

sequelize
    .authenticate()
    .then(() => {
      console.log('Connection has been established successfully.'); // eslint-disable-line no-console
    })
    .catch((err) => {
      console.error('Unable to connect to the database:', err); // eslint-disable-line no-console
    });

app.use((req, res, next) => {
  res.setHeader('Access-Control-Allow-Origin', '*');
  res.setHeader('Access-Control-Allow-Headers', 'Origin, X-Requested-With, Content, Accept, Content-Type, Authorization');
  res.setHeader('Access-Control-Allow-Methods', 'GET, POST, PUT, DELETE, PATCH, OPTIONS');
  next();
});

app.use(bodyParser.json());

module.exports = app;
这是我的match.js路由器文件:

    const express = require('express');
const router = express.Router();
const controller = require('../controllers/match');
const auth = require('../middleware/auth');

router.get('/getAllMatches', controller.getAllMatches);

module.exports = router;
这是我的小型控制器文件:

const Event = require('../models/Event')

exports.createMatch = (req, res, next) => {
    delete req.body.id;
    const Event = new Event(...req.body);
    Event.save()
        .then(() => res.status(200).json({
            message:'Match créé avec succès'
        }))
        .catch((error) => res.status(400).json({ error : error }));
};

exports.getAllMatches = (req, res, next) => {
    Event.findAll()
        .then((events) => {
            res.status(200).json(events);
        })
        .catch((error) => {
            res.status(400).json({ error : error });
        })
};

你看到我的代码有问题吗?

如果你把app.use/放在所有路由之前,那么其他路由如何工作。

这不是问题,当你使用app.use/时,有些路由只是从某些路由导入的所有路由的前缀,这不是问题所在。谢谢你试着帮助我;