【问题标题】:Express Server continuously throws 404 errorExpress Server 连续抛出 404 错误
【发布时间】:2020-08-10 18:03:23
【问题描述】:

我不断收到这些错误。

这是我的一些代码。

bin/www

#!/usr/bin/env node

/**
 * Module dependencies.
 */

var app = require('../app');
var debug = require('debug')('server:server');
var http = require('http');

/**
 * Get port from environment and store in Express.
 */

var port = normalizePort(process.env.PORT || '3000');
app.set('port', port);

/**
 * Create HTTP server.
 */

var server = http.createServer(app);

/**
 * Listen on provided port, on all network interfaces.
 */

server.listen(port);
server.on('error', onError);
server.on('listening', onListening);

/**
 * Normalize a port into a number, string, or false.
 */

function normalizePort(val) {
  var port = parseInt(val, 10);

  if (isNaN(port)) {
    // named pipe
    return val;
  }

  if (port >= 0) {
    // port number
    return port;
  }

  return false;
}

/**
 * Event listener for HTTP server "error" event.
 */

function onError(error) {
  if (error.syscall !== 'listen') {
    throw error;
  }

  var bind = typeof port === 'string'
    ? 'Pipe ' + port
    : 'Port ' + port;

  // handle specific listen errors with friendly messages
  switch (error.code) {
    case 'EACCES':
      console.error(bind + ' requires elevated privileges');
      process.exit(1);
      break;
    case 'EADDRINUSE':
      console.error(bind + ' is already in use');
      process.exit(1);
      break;
    default:
      throw error;
  }
}

/**
 * Event listener for HTTP server "listening" event.
 */

function onListening() {
  var addr = server.address();
  var bind = typeof addr === 'string'
    ? 'pipe ' + addr
    : 'port ' + addr.port;
  debug('Listening on ' + bind);
} 

app.js

var createError = require('http-errors');
var express = require('express');
var path = require('path');
var cookieParser = require('cookie-parser');
var logger = require('morgan');
var mongoose = require('mongoose');

var eventsRouter = require('./routes/events');
var usersRouter = require('./routes/users');

var app = express();

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

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((req, res, next) => {
  res.setHeader('Access-Control-Allow-Origin', '*');
  res.setHeader('Access-Control-Allow-Headers', 'Origin, X-Requested, Content-Type, Accept, Authorization');
  res.setHeader(
    'Access-Control-Allow-Methods',
    'GET, POST, PATCH, DELETE, OPTIONS')
  next();
});

app.use('/dashboard', eventsRouter);
app.use('/user', 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');
});

mongoose.connect('// this is good just deleted for post')
  .then(() => {
    console.log("Connected to database!");
  })
  .catch(() => {
    console.log("Connection failed.")
  });

module.exports = app;

users.js

const express = require('express');
const bcrypt = require('bcrypt');
const jwt = require('jsonwebtoken');
const router = express.Router();

const User = require('../models/user');

router.post('/signup', (req, res, next) => {
  bcrypt.hash(req.body.password, 10)
    .then(hash => {
      const user = new User({
        firstName: req.body.firstName,
        lastName: req.body.lastName,
        userName: req.body.userName,
        email: req.body.email,
        password: hash
      });
      user.save()
        .then(result => {
          res.status(201).json({
            msg: "User Created",
            rslt: result
          });
        })
        .catch(err => {
          res.status(500).json({
            err: err
          });
        });
    });
});

router.post("/login", (req, res, next) => {
  let fetchedUser;
  User.findOne({ email: req.body.email })
    .then(user => {
      if (!user) {
        return res.status(401).json({
          msg: "Auth Failed."
        });
      }
      fetchedUser = user;
      return bcrypt.compare(req.body.password, user.password)
    })
    .then(result => {
      if (!result) {
        return res.status(401).json({
          msg: "Auth Failed."
        });
      }
      const token = jwt.sign(
        { email: fetchedUser.email, userId: fetchedUser._id },
        // ,
        { expiresIn: '1h' }
      );
      res.status(200).json({
        token: token
      });
    })
    .catch(err => {
      return res.status(401).json({
        msg: err
      });
    });
});

router.post("/profile", (req, res, next) => {

})

module.exports = router;

events.js

var express = require('express');
var router = express.Router();

const Event = require('../models/event');
const checkAuth = require('../middleware/check-auth');

router.post("/createEvent", checkAuth, (req, res, next) => {
  const event = new Event({
    title: req.body.title,
    description: req.body.description,
    date: req.body.date,
    time: req.body.time,
    location: req.body.location,
    invite: req.body.invite,
    private: req.body.private
  });
  event.save()
    .then(result => {
      res.status(201).json({
        msg: "Event Created",
        rslt: result
      });
    })
    .catch(err => {
      res.status(500).json({
        err: err
      });
    });

});
module.exports = router;

关于我做错了什么的任何建议。这是我几个月前开始的一个项目,当然,还没有完成。我最近才回到它,似乎无法弄清楚为什么我的服务器无法工作。似乎与数据库连接良好。

【问题讨论】:

    标签: node.js angular mongodb express server


    【解决方案1】:

    如我所见,您输入了“/”网址,但在您的代码中没有“/”路线。

    你能添加下面的'home'路线,请再检查一下吗?

    app.use('/dashboard', eventsRouter);
    app.use('/user', usersRouter);
    
    // catch 404 and forward to error handler
    // app.use(function(req, res, next) {
    //   next(createError(404));
    // });
    
    app.get('/', (req, res) => {
       res.send('home');
    });
    
    // 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');
    });
    

    【讨论】:

    • 我没有出错,屏幕上显示主页。但是,我仍然无法使用我的 localhost:3000/dashboard 或 localhost:3000/user 路由。
    • @RickyMed soo 分享这两个文件的内容,可能里面有什么问题...
    • 我刚刚更新了帖子。虽然我什至不能去 localhost:3000/user。更不用说 localhost:3000/user/signup。
    【解决方案2】:

    @RickyMed 您是否为/ 路由定义了任何中间件。通常404 Not Found 在不存在 url 时出现。如果没有创建一个或尝试http://localhost:3000/user。 检查这是否有效

    【讨论】:

    • 是的,这是有道理的。 Benard Patrick 建议的解决方案适用于 localhost:3000 但无法显示我的其他路线。
    • @RickyMed 检查呼叫是否进入您定义的那些侦听器。做一些控制台日志并检查你是否发送回任何资源
    • 我正在尝试听,但当我尝试时甚至不再编译代码。
    猜你喜欢
    • 2023-03-15
    • 2017-11-29
    • 2012-07-24
    • 2023-03-26
    • 1970-01-01
    • 1970-01-01
    • 2023-04-03
    • 2021-12-02
    • 2021-09-27
    相关资源
    最近更新 更多