Knoten JS LDAP Auth User

Ich erstelle eine Anmeldeauthentifizierungsseite, auf der ein Benutzer den Benutzernamen und das Kennwort für das aktive Verzeichnis eingibt. Mit NodeJS überprüfe ich, ob es gültig ist, erhalte jedoch weiterhin Informationen

[Error: LDAP Error Bad search filter]

oder

[Error: Search returned != 1 results]

Wenn ich versuche, nach dem Benutzernamen und dem Passwort zu suchen, ist mein Code unten:

Ich benutze:https://github.com/jeremycx/node-LDAPNehmen wir an, der Benutzer hat einen Benutzernamen von hhill eingegeben

    var ldap = require('LDAP');
    var ldapServer = new ldap({ uri: 'ldap://batman.lan', version: 3});

    ldapServer.open(function(error) {
        if(error) {
           throw new Error('Cant not connect');
        } else {
            console.log('---- connected to ldap ----');

            username = '(cn='+username+')';
            ldapServer.findandbind({
                base: 'ou=users,ou=compton,dc=batman,dc=lan',
                filter: username,
                password: password
            }, function(error, data) {
                if(error){
                    console.log(error);
                } else {
                    console.log('---- verified user ----');
                }
            });
        }
    });

Hat jemand Vorschläge, was ich falsch mache?

AKTUALISIEREN

Hier ist die Lösung, die ich mit Hilfe der folgenden Antwort gefunden habe, falls jemand sie jemals benötigt

    var username = request.param('username');
    var password = request.param('password');

    var ldap = require('ldapjs');
    ldap.Attribute.settings.guid_format = ldap.GUID_FORMAT_B;
    var client = ldap.createClient({
          url: 'ldap://batman.com/cn='+username+', ou=users, ou=compton, dc=batman, dc=com',
          timeout: 5000,
          connectTimeout: 10000
    });
    var opts = {
      filter: '(&(objectclass=user)(samaccountname='+username+'))',
      scope: 'sub',
      attributes: ['objectGUID']
    };

    console.log('--- going to try to connect user ---');

    try {
        client.bind(username, password, function (error) {
            if(error){
                console.log(error.message);
                client.unbind(function(error) {if(error){console.log(error.message);} else{console.log('client disconnected');}});
            } else {
                console.log('connected');
                client.search('ou=users, ou=compton, dc=batman, dc=com', opts, function(error, search) {
                    console.log('Searching.....');

                    search.on('searchEntry', function(entry) {
                        if(entry.object){
                            console.log('entry: %j ' + JSON.stringify(entry.object));
                        }
                    });

                    search.on('error', function(error) {
                        console.error('error: ' + error.message);
                    });

                    client.unbind(function(error) {if(error){console.log(error.message);} else{console.log('client disconnected');}});
                });
            }
        });
    } catch(error){
        console.log(error);
        client.unbind(function(error) {if(error){console.log(error.message);} else{console.log('client disconnected');}});
    }

Antworten auf die Frage(2)

Ihre Antwort auf die Frage