Исключение нулевого указателя - это индикатор того, что вы используете объект, не инициализируя его.
Например, ниже - класс ученика, который будет использовать его в нашем коде.
public class Student {
private int id;
public int getId() {
return this.id;
}
public setId(int newId) {
this.id = newId;
}
}
Приведенный ниже код дает вам исключение с нулевым указателем.
public class School {
Student obj_Student;
public School() {
try {
obj_Student.getId();
}
catch(Exception e) {
System.out.println("Null Pointer ");
}
}
}
Поскольку вы используете Obj_Student
, но вы забыли инициализировать его, как в правильном коде, показанном ниже:
public class School {
Student obj_Student;
public School() {
try {
obj_Student = new Student();
obj_Student.setId(12);
obj_Student.getId();
}
catch(Exception e) {
System.out.println("Null Pointer ");
}
}
}
Я отсутствовал
l.set_option(ldap.OPT_REFERRALS, 0)
От init.
Если Вы открыты для использования pywin32, можно использовать вызовы Win32 из Python. Это - то, что мы делаем в нашем веб-сервере CherryPy:
import win32security
token = win32security.LogonUser(
username,
domain,
password,
win32security.LOGON32_LOGON_NETWORK,
win32security.LOGON32_PROVIDER_DEFAULT)
authenticated = bool(token)
Я вижу Ваш комментарий к @Johan Бюретке о DN, не решающем Вашу проблему, но я также верю тому, именно это необходимо изучить.
, Учитывая Ваш пример, DN для учетной записи администратора по умолчанию в AD будет: cn=Administrator, cn=Users, dc=mydomain, dc=co, dc=uk - попробуйте это.
Используйте Отличительное имя для вхождения в систему. "CN=Your user,CN=Users,DC=b2t,DC=local"
Это должно работать над любой системой LDAP, включая AD
У меня это сработало, l.set_option (ldap.OPT_REFERRALS, 0) был ключом для доступа к ActiveDirectory. Более того, я считаю, что вам следует добавить con.unbind (), чтобы закрыть соединение до завершения скрипта.