javascript - EJS 表单中的 App.post 不起作用 - ExpressJS

标签 javascript node.js express

我正在使用带有 EJS 的 Express 框架作为 View 引擎。我在应用程序中有一些基本路线(“/”和“/users”)。我的 EJS 页面中还有一个表单,我正在使用用户登录。这里我有带有action =“/login”和method =“POST”的表单。我在 app.js 中创建了一个处理函数 app.post 来检查凭据并重定向到用户页面。

但是当我单击页面 Express 应用程序的提交按钮时,显示“/login”未找到。下面是整个应用程序的目录结构。 enter image description here

菜单.ejs:


    <form method="POST" action="/login">
        <input type="text" name="username" placeholder="Username">
        <input type="password" name="password" placeholder="Password">
        <input type="submit" name="login" class="login loginmodal-submit" value="Login">
    </form>

还有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 session = require('express-session');
var mysql = require('mysql');
var bodyParser = require('body-parser');
var path = require('path');

var indexRouter = require('./routes/index');
var usersRouter = require('./routes/users');
var loginRouter = require('./routes/login');

var app = express();

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

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.use('/login', loginRouter);

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

//express session
app.use(session({
  secret:'secret_key',
  resave:true,
  saveUninitialized:true
}));
app.use(bodyParser.urlencoded({
  extended:true
}));
app.use(bodyParser.json());
mysql
var connection = mysql.createConnection({
  host:'localhost',
  user:'root',
  password:'secret_pw',
  database:'my_db'
});

//login authentication
app.post('/login', function(req,res){
  var username = req.body.username;
  var password = req.body.password;
  if(username && password){ 
      connection.query('SELECT username,password FROM logindetails WHERE username = ? AND password = ?',[username,password], function(error,results,fields){
          if(results.length > 0){
              req.session.loggedin = true;
              req.session.username = username;
              res.redirect('/users');
          } else{
              res.send('Incorrect username and password');
          }
          res.end();
      });
  }
   else{
       res.send('Please enter username and password');
       res.end();
   }
});

module.exports = app;

登录路径是

var express = require('express');
var router = express.Router();
/* GET home page. */
router.get('/', function(req, res, next) {
  res.render('index', { page:'home', menuId:'home' });
});



module.exports = router;

最佳答案

从 app.js 中省略此代码

app.post('/login', function(req,res){
   /....../
});

然后将其添加到登录路由器

router.post('/', function(req, res) {
  /......../
});

关于javascript - EJS 表单中的 App.post 不起作用 - ExpressJS,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/59065621/

相关文章:

javascript - 如何将集合中的所有条目显示为 html (node.js)

javascript - 使用 node express 从类渲染方法

node.js - 使用 Superagent 和 Express 4 接收 POST 请求数据

javascript - Chrome 在从 libwebsockets 接收时说 "Could not decode a text frame as UTF-8"

javascript - html 内的复选框检查

javascript - JQUERY JSON响应触发解析错误

mysql - 我该如何解决这个问题? ( Node 、mysql 和异步/等待)

javascript - 转换 Javascript 日期时出现问题

javascript - 获取 JSON 并处理 JSON 中的各个信息

node.js - 如何在 Node.js Express mongoose 后端的 URL 查询字符串中使用 $or 运算符