使用jwt与护照得到404错误

问题描述 投票:1回答:1

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

我遵循一些教程:tuto1 tuto2 tuto3但我总是得到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 ;

感谢帮助 !

node.js express jwt passport-local
1个回答
0
投票

passport.use(“局部式登入”,

passport.authenticate( '本地',

这种不一致是一个问题吗?

© www.soinside.com 2019 - 2024. All rights reserved.