我正在为我的公司开发一个需要用户登录的应用程序。为了自动化登录过程,我尝试将ldap id和密码身份验证与该应用程序集成。下面是我为这个集成编写的代码。我在网上查过,找不到任何人面临这个问题。
我有这个代码->
function isAuthenticated($u,$p) {
$ldap_host = 'my_host';
$ldap = ldap_connect($ldap_host);
ldap_set_option(NULL, LDAP_OPT_DEBUG_LEVEL, 7);
if($ldap) {
if($bind = ldap_bind($ldap,$u,$p)) {
ldap_unbind($ldap);
return 'Authenticated';
} else {
return 'Invalid Credentials';
}
} else {
return 'Not able to connect';
}
}
$username = 'preventAnonymousLogin';
$password = 'preventAnonymousLogin';
if(isset($_REQUEST['uname'])) {
$username = $_REQUEST['uname'];
}
if(isset($_REQUEST['password'])) {
$password = $_REQUEST['password'];
}
$auth = isAuthenticated($username,$password);
这在大多数情况下都有效,但有时却不起作用,并出现此错误->
Fatal error: Maximum execution time of 30 seconds exceeded in C:'xampp'htdocs'avrs'htdocs'ldap.php on line 12
我不知道为什么这有时会起作用,有时却不起作用。请提出建议。提前谢谢。
同样的代码间歇性地工作。我试着清理饼干,所有这些似乎都奏效了,但今天不行。所以,除非我确定问题是什么,否则我想我无法永远解决这个问题。
确保提供ldap_host的完整DNS名称,例如myhost.mydomain.com.
根据错误,您可以尝试将C:''examplep''htdocs''avrs''htdocs''ldap.php中的最大脚本执行时间设置为60秒或大于30秒。从上面的代码来看,它看起来像
function isAuthenticated($u,$p) {
set_time_limit(60);
// Rest of your code from above
}
set_time_limit文档
看看这些例子。第一个是一个非常简单的LDAP/activedirectory登录脚本。第二个实际上是为Yii框架构建的,但更健壮的是,它可以在其中一个服务器出现故障时使用多个服务器。
简单LDAP/Active Directory表单
Yii Active Directory用户标识