LDAP работает с PHP CLI, но не через apache - PullRequest
3 голосов
/ 28 ноября 2011

Я пытаюсь пройти аутентификацию через LDAP для Windows 2008 Server из коробки Fedora.

Следующий код работает из командной строки (выводит «Success»):

if($ldap = ldap_connect('10.0.0.101'))
{
  ldap_set_option($ldap, LDAP_OPT_PROTOCOL_VERSION, 3);
  $bind = ldap_bind($ldap,'administrator@domain.tld','XXXXXXX');
  print ldap_error($ldap);
}

... извлечение того же файла через Apache / mod_php печатает "Can't contact LDAP server"

Я видел много сообщений о подобных проблемах, но никакой полезной информации о том, как их решить.

Ответы [ 2 ]

7 голосов
/ 27 февраля 2013

Я только что долго боролся с этой проблемой на centos6.Разница в php.ini кажется хорошим местом для проверки, но она не дала мне ответа.Оказывается, это было связано с SELinux.

$ getsebool -a | grep httpd
allow_httpd_anon_write --> off
allow_httpd_mod_auth_ntlm_winbind --> off
allow_httpd_mod_auth_pam --> off
allow_httpd_sys_script_anon_write --> off
httpd_builtin_scripting --> on
httpd_can_check_spam --> off
httpd_can_network_connect --> off
httpd_can_network_connect_cobbler --> off
httpd_can_network_connect_db --> on
httpd_can_network_memcache --> on
httpd_can_network_relay --> off
httpd_can_sendmail --> off
httpd_dbus_avahi --> on
httpd_enable_cgi --> on
httpd_enable_ftp_server --> off
httpd_enable_homedirs --> off
httpd_execmem --> off
httpd_manage_ipa --> off
httpd_read_user_content --> off
httpd_run_stickshift --> off
httpd_setrlimit --> off
httpd_ssi_exec --> off
httpd_tmp_exec --> off
httpd_tty_comm --> on
httpd_unified --> on
httpd_use_cifs --> off
httpd_use_gpg --> off
httpd_use_nfs --> off
httpd_use_openstack --> off
httpd_verify_dns --> off

Вы заметите, что в моем случае httpd_can_network_connect был отключен.Это логическое значение в SELinux, и его можно настроить с помощью следующей команды:

$ setsebool -P httpd_can_network_connect on

Подробнее об этом можно прочитать по адресу http://wiki.centos.org/TipsAndTricks/SelinuxBooleans, который в качестве примера явно использует регистр apache и ldap.Надеюсь, это поможет!

1 голос
/ 28 ноября 2011

Эта проблема может возникать из-за того, что в Apache есть один файл php.ini, а в CLI может быть другой, а в версии Apache может не быть включено расширение LDAP.

Попробуйте проверить, какая php.ini загружается с phpinfo() в обеих ваших средах:

<?php print phpinfo(); ?>

Вы должны увидеть путь php.ini и дополнительную полезную информацию:

Configuration File (php.ini) Path => /etc/php5/cli
Loaded Configuration File => /etc/php5/cli/php.ini
Scan this dir for additional .ini files => /etc/php5/cli/conf.d

Альтернативный способ просмотра конфигурации, загруженной на CLI, заключается в вызове php с параметром -i:

$ php -i | grep 'php.ini'
Configuration File (php.ini) Path => /etc/php5/cli
Loaded Configuration File => /etc/php5/cli/php.ini
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...