NodeJS-LDAPJS错误:events.js:160 throw er; //未处理的“错误”事件

时间:2019-06-28 06:58:21

标签: javascript node.js ldapjs

所有我对nodejs都是陌生的,并且在执行节点文件时遇到了这个问题。我在centos 7上。当我尝试使用LDAPJS连接到LDAP时。当LDAP可用时,它可以正常工作,但随后无法连接到服务器,则显示此奇怪的错误:

  

events.js:160         投掷者//未处理的“错误”事件         ^

     

错误:连接EHOSTUNREACH 172.24.130.203:389       在Object.exports._errnoException(util.js:1020:11)       在exports._exceptionWithHostPort(util.js:1043:20)       在TCPConnectWrap.afterConnect上[完成时](net.js:1099:14)

我想捕获此错误并显示正确的错误消息。

我已经尝试使用了

 rm -rf node_modules && npm cache clean --force && npm install

但这没有帮助。

我的package.json文件是:

{
  "name": "package",
  "version": "1.0.0",
  "description": "For LDAP ",
  "main": "index.js",
  "dependencies": {
    "ldap": "^0.7.1",
    "passport": "^0.4.0"
  },
  "devDependencies": {},
  "scripts": {
    "test": "node index.js"
  },
  "keywords": [
    "ldapjs"
  ],
  "author": "Rajan",
  "license": "ISC"
}

这是index.js文件:

var ldap = require('ldapjs');
var http = require('http');
var assert = require('assert');


var client = ldap.createClient({
    url: 'ldap://172.24.130.203/dc=india,dc=bizrtc,dc=com'
});

var basedn = "dc=test,dc=test,dc=test";

var opts = {
  filter: '(ipPhone=*)',
  scope: 'sub',
  attributes: ['ipPhone','mail','name','description']
};

client.bind('username', 'mysecret', function (err) {

client.search('dc=india,dc=bizrtc,dc=com', opts, function (err, search) {
    search.on('searchEntry', function (entry) {
      var user = entry.object;
      console.log("Users are " + user.ipPhone + "  Display Name is  " + user.name + " E-Mail is " + user.mail + " Password is  " + user.description);

    });

  });
});


client.unbind(function(err) {
  assert.ifError(err);
});

1 个答案:

答案 0 :(得分:0)

看起来,客户端捕获套接字错误并重新发出这些错误: Client - error

所以你应该喜欢类似的东西

client.on('error', err => { console.error(err) })