我已通过此链接How To Install and Configure a Basic LDAP Server 在本地系统中设置了LDAP服务器。我想让LDAP服务器运行并能够通过phpldapadmin
添加组,用户等。我添加了一个用户,如图
要在LDAP服务器中确认用户,请使用以下命令
$ ldapsearch -x -W -D 'cn=thiru niren,cn=users,ou=group,dc=test,dc=com' -b "" -s base -H ldap://192.168.2.4
它问我密码然后输入密码我得到了结果
Enter LDAP Password:
# extended LDIF
#
# LDAPv3
# base <> with scope baseObject
# filter: (objectclass=*)
# requesting: ALL
#
#
dn:
objectClass: top
objectClass: OpenLDAProotDSE
# search result
search: 2
result: 0 Success
# numResponses: 2
# numEntries: 1
然后我尝试使用passport-ldapauth模块。我为此编写的代码是
var LdapStrategy = require('passport-ldap').Strategy,
passport = require('passport');
passport.use(new LdapStrategy({server: {
url: 'ldap://192.168.2.4',
adminDn:'cn=thiru niren,cn=users,ou=group,dc=test,dc=com',
adminPassword: 'infra'
}},
function(user, done) {
console.log("user authenticated or not");
return done(null, user);
}
));
console.log("check ldap");
执行此代码后,我只看到check ldap
并在terminal
中保持闪烁的光标。然后我提出了console.log("user authenticated or not");
以验证LdapStrategy
是否有callback
函数,但我在控制台中看不到user authenticated or not
而是check ldap
。会出现什么问题?为什么passport-ldapaut
没有得到ldap服务器的响应?
我正在使用ubuntu 14.04 LTS。 node --version是v0.10.28。
更新 我尝试使用ldapauth模块,但没有运气我得到相同的结果,检查我上面提到的网站的修改代码
var connect = require('connect');
var LdapAuth = require('ldapauth');
// Config from a .json or .ini file or whatever.
var config = {
ldap: {
url: "ldap://192.168.2.4:389",
adminDn: "cn=thiru niren,cn=users,ou=group,dc=test,dc=com",
adminPassword: "infra",
searchBase: "ou=group,dc=test,dc=com",
searchFilter: "(uid=tniren)"
}
};
var ldap = new LdapAuth({
url: config.ldap.url,
adminDn: config.ldap.adminDn,
adminPassword: config.ldap.adminPassword,
searchBase: config.ldap.searchBase,
searchFilter: config.ldap.searchFilter,
//log4js: require('log4js'),
cache: true
});
//console.log("we here",ldap);
var basicAuthMiddleware = connect.basicAuth(function (username, password, callback) {
console.log("we");
ldap.authenticate(username, password, function (err, user) {
console.log("we are");
if (err) {
console.log("LDAP auth error: %s", err);
}
callback(err, user)
});
});
这里我也没有得到ldap
服务器的任何回复,服务器有什么问题吗?