将 jwt 与护照一起使用会出现 404 错误

using jwt with passport get 404 error

我尝试使用 Express、Passport、Jwt、本地护照和 Mariadb 创建身份验证 api。 我不需要用户模型,但想使用 sql 调用。

我遵循一些教程:tuto1 tuto2 tuto3 但是我总是用 curl 和邮递员得到 404 错误(POST 请求)。 不知道哪里出了问题。

app.js

var express = require('express');
var logger = require('morgan');
var path = require('path');
var _ = require("lodash");
var favicon = require('serve-favicon');
var app = express();
var cookieParser = require('cookie-parser');
var bodyParser = require('body-parser');

var routes = require('./routes/routes')
var passport = require("passport");

app.use(logger('dev'));
app.use(bodyParser.json());
app.use(bodyParser.urlencoded({ extended: true }));
app.use(cookieParser());
app.use(express.static(path.join(__dirname, 'public')));

app.use(passport.initialize());
app.use('/', routes);

// catch 404 and forward to error handler
app.use(function(req, res, next) {
var err = new Error('Not Found');
err.status = 404;
next(err);
 });

// 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.json({ error: err });
});

module.exports = app;

passport.js

var passport    = require('passport');
var passportJWT = require("passport-jwt");

var ExtractJWT = passportJWT.ExtractJwt;

var LocalStrategy = require('passport-local').Strategy;
var JWTStrategy   = passportJWT.Strategy;

var connection = require('./database');
var sodium = require('./sodium');

passport.use('local-signin', new LocalStrategy({
usernameField: 'username',
passwordField: 'password'
} , function (req, username, password, done){
  if(!username || !password ) {
    return done(null, false);
    }
  connection.query("select * from users where username = ?", [username], 
 function(err, rows){
      console.log(err);
      console.log(rows);
    if (err)
    return done(null, error);
    if(!rows.length){
      return done(null, false);
    }
    var dbpassword = rows[0].password;
    if(sodium.password_check(dbpassword, password) == false){
        return done(null, false);
     }
       return done(null, rows[0]);
   });
  })
);

passport.use(new JWTStrategy({
    jwtFromRequest: ExtractJWT.fromAuthHeaderAsBearerToken(),
    secretOrKey   : 'your_jwt_secret'
 },
 function (jwtPayload, cb) {
   connection.query("select * from users where id = ?", [jwtPayload.id], 
function(err, rows){
      console.log(err);
      console.log(rows);
    if (err)
    return done(null, error);
    if(!rows.length){
      return done(null, false);
    }
    var dbpassword = rows[0].password;
    if(sodium.password_check(dbpassword, password) == false){
        return done(null, false);
     }
       return done(null, rows[0]);
   });
  }
));

module.exports = passport ;

routes.js

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

const jwt      = require('jsonwebtoken');
const passport = require('passport');

router.post('/', function (req, res, next) {
passport.authenticate('local-signin', {session: false}, (err, user, info) => {
    if (err || !user) {
        return res.status(400).json({
            message: 'Something is not right',
            user   : user
        });
    }
   req.login(user, {session: false}, (err) => {
       if (err) {
           res.send(err);
       }
       const token = jwt.sign(user, 'my_secret');
       return res.json({user, token});
    });
     })
   (req, res);
 });

 module.exports = router ;

感谢帮助!

passport.use('local-signin',

passport.authenticate('local',

这种不一致会成为问题吗?