2013-10-30 11 views

Antwort

4

Vielleicht hilft Ihnen so etwas beim Einstieg.

var failures = {}; 

function tryToLogin() { 
    var f = failures[remoteIp]; 
    if (f && Date.now() < f.nextTry) { 
     // Throttled. Can't try yet. 
     return res.error(); 
    } 

    // Otherwise do login 
    ... 
} 

function onLoginFail() { 
    var f = failures[remoteIp] = failures[remoteIp] || {count: 0, nextTry: new Date()}; 
    ++f.count; 
    f.nextTry.setTime(Date.now() + 2000 * f.count); // Wait another two seconds for every failed attempt 
} 

function onLoginSuccess() { delete failures[remoteIp]; } 

// Clean up people that have given up 
var MINS10 = 600000, MINS30 = 3 * MINS10; 
setInterval(function() { 
    for (var ip in failures) { 
     if (Date.now() - failures[ip].nextTry > MINS10) { 
      delete failures[ip]; 
     } 
    } 
}, MINS30); 
+0

Dies füllt langsam Ihren Arbeitsspeicher, da die fehlgeschlagenen IPs niemals aus "Fehlern" gelöscht werden, wenn ein Login niemals erfolgreich ist. – josh3736

+0

@ josh3736 Guter Punkt. Eine Funktion hinzugefügt, um es alle 30 Minuten zu reinigen. –

+2

Was halten Sie von Lösungen wie Express-Brute? https://npmjs.org/package/express-brute – Dave

7

So, nachdem einige der Suche zu tun, ich war ich so schrieb ich meine eigenen mochte, eine Lösung zu finden, nicht in der Lage, basierend auf Trevors Lösung und Express-Tier. Sie können es here finden.

0

okk, ich fand die Lösung von max Login versuch auf falsches Passwort in mongoose und expressjs.there ist eine Lösung. * Zuerst werden wir das Benutzerschema definieren * Sekunde werden wir die maximale Anmeldung auf falsepassword Handler-Funktion definieren. * Drittel, wenn wir die Login api schaffen, dann werden wir diese Funktion prüfen, ob, wie oft User-Login mit falscher password.so für Code bereit seine

var config = require('../config'); 


var userSchema = new mongoose.Schema({ 
    email: { type: String, unique: true, required: true }, 
    password: String, 
    verificationToken: { type: String, unique: true, required: true }, 
    isVerified: { type: Boolean, required: true, default: false }, 
    passwordResetToken: { type: String, unique: true }, 
    passwordResetExpires: Date, 
    loginAttempts: { type: Number, required: true, default: 0 }, 
    lockUntil: Number, 
    role: String 
}); 

userSchema.virtual('isLocked').get(function() { 
    return !!(this.lockUntil && this.lockUntil > Date.now()); 
}); 
userSchema.methods.incrementLoginAttempts = function(callback) { 
    console.log("lock until",this.lockUntil) 
    // if we have a previous lock that has expired, restart at 1 
    var lockExpired = !!(this.lockUntil && this.lockUntil < Date.now()); 
console.log("lockExpired",lockExpired) 
    if (lockExpired) { 
     return this.update({ 
      $set: { loginAttempts: 1 }, 
      $unset: { lockUntil: 1 } 
     }, callback); 
    } 
// otherwise we're incrementing 
    var updates = { $inc: { loginAttempts: 1 } }; 
     // lock the account if we've reached max attempts and it's not locked already 
    var needToLock = !!(this.loginAttempts + 1 >= config.login.maxAttempts && !this.isLocked); 
console.log("needToLock",needToLock) 
console.log("loginAttempts",this.loginAttempts) 
    if (needToLock) { 
     updates.$set = { lockUntil: Date.now() + config.login.lockoutHours }; 
     console.log("config.login.lockoutHours",Date.now() + config.login.lockoutHours) 
    } 
//console.log("lockUntil",this.lockUntil) 
    return this.update(updates, callback); 
}; 

hier ist meine Login-Funktion, wo wir das überprüft haben max Anmeldeversuch auf falsche password.so nennen wir diese Funktion

User.findOne({ email: email }, function(err, user) { 
     console.log("i am aurhebengdfhdbndbcxnvndcvb") 
     if (!user) { 
      return done(null, false, { msg: 'No user with the email ' + email + ' was found.' }); 
     } 

     if (user.isLocked) { 
      return user.incrementLoginAttempts(function(err) { 
       if (err) { 
        return done(err); 
       } 

       return done(null, false, { msg: 'You have exceeded the maximum number of login attempts. Your account is locked until ' + moment(user.lockUntil).tz(config.server.timezone).format('LT z') + '. You may attempt to log in again after that time.' }); 
      }); 
     } 

     if (!user.isVerified) { 
      return done(null, false, { msg: 'Your email has not been verified. Check your inbox for a verification email.<p><a href="/user/verify-resend/' + email + '" class="btn waves-effect white black-text"><i class="material-icons left">email</i>Re-send verification email</a></p>' }); 
     } 

     user.comparePassword(password, function(err, isMatch) { 
      if (isMatch) { 
       return done(null, user); 
      } 
      else { 
       user.incrementLoginAttempts(function(err) { 
        if (err) { 
         return done(err); 
        } 

        return done(null, false, { msg: 'Invalid password. Please try again.' }); 
       }); 
      } 
     }); 
    }); 
})); 
+0

meine config.js Datei ist hier –