I am trying to integrate passport to my code\'s login form. Client side calling server side works as it should until i call passport.authenticate in the request, 400 Bad Request
In my case (Express 4.0), I wasn't using body-parser
passport.use(new LocalStrategy(
{
usernameField: 'email',
passwordField: 'password'
},
function (email, password, done) {
db.collection('User').findOne({ email: email }, async function (err, user) {
console.log('user requested password caught in passport', password);
if (err) { return done(err); }
if (!user) { return done(null, false); }
const matchPassword = await comparePassword(password, user.password);
if (!matchPassword) { return done(null, false); }
return done(null, user);
});
}
));
This error also comes from trying to access the HTML DOM elements without using body-parser
body-parser is a module that let's you traverse the html document tree to read response especially in case of input fields
Use -
var parser = require('body-parser');
var urlencodedParser = parser.urlencoded({extended : false});
app.post("/authenticate", urlencodedParser, passport.authenticate('local'), function (request, response)
{
response.redirect('/');
});
Bad Request was thrown by passport for missing access on username and password.
It is checking body and URL query for fields username
and password
. If either is falsy the request is rejected with status 400.
On creating your LocalStrategy you may pass set of options in additional argument to constructor choosing differently named fields using options usernameField
and/or passwordField
. In your particular case this would look like this:
passport.use(new LocalStrategy(
{usernameField:"user-email", passwordField:"user-password"},
function(username, password, done) {
return done(null, false, {message:'Unable to login'})
}
));