У меня есть два php-файла для аутентификации пользователей активного каталога, я хочу получить атрибут url
от него и передать эту переменную $data
от authenticate.php
в login.php
если функция вернула true, чтобы быть в расположении header("Location: *URL*");
,Как это может быть сделано?
authenticate.php:
<?php
// Initialize session
session_start();
function authenticate($user, $password) {
if(empty($user) || empty($password)) return false;
// Active Directory server
$ldap_host = "CRAMSDCR01V.cloud4rain.local";
// connect to active directory
$ldap = ldap_connect($ldap_host);
$ldap_dn="OU=by-style,DC=cloud4rain,DC=local";
// verify user and password
if($bind = @ldap_bind($ldap, $user, $password))
{
$result = ldap_search($ldap,$ldap_dn, "(cn=*)") or die ("Error in search query: ".ldap_error($ldap));
$data = ldap_get_entries($ldap, $result);
echo $data["url"];
return true;
}
else
{
// invalid name or password
return false;
}
}
?>
login.php:
<?php
include("authenticate.php");
// check to see if user is logging out
if(isset($_GET['out'])) {
// destroy session
session_unset();
$_SESSION = array();
unset($_SESSION['user'],$_SESSION['access']);
session_destroy();
}
// check to see if login form has been submitted
if(isset($_POST['btn-login'])){
// run information through authenticator
if(authenticate($_POST['userLogin'],$_POST['userPassword']))
{
// authentication passed
header("Location: authenticate.php?$data");
die();
} else {
// authentication failed
$error = "Login failed: Incorrect user name, password, or rights<br /-->";
}
}
// output logout success
if(isset($_GET['out'])) echo "Logout successful";
?>
login.php
<?php
include("authenticate.php");
По сути, это действует как вставка содержимого authenticate.php внутри login.php так что, хотя это технически 2 файла, он действует так, как будто это только один — однако $data
определяется в рамках authenticate()
функция и так только в рамках этой функции.
В authenticate.php — вернуть данные из функции
// verify user and password
if($bind = @ldap_bind($ldap, $user, $password))
{
$result = ldap_search($ldap,$ldap_dn, "(cn=*)") or die ("Error in search query: ".ldap_error($ldap));
$data = ldap_get_entries($ldap, $result);
// echo $data["url"]; // I assume this is just for debugging...
// return $data from the function which should be "truthy"return $data;
}
else
{
// invalid name or password
return false;
}
В login.php — оценить отдачу от authenticate()
функция — поскольку PHP свободно набирается, любая (непустая) строка, возвращаемая функцией, может быть оценена как «Truthy» — единственные другие возвраты, которые у вас есть от функции: false
так…
// run information through authenticator
if($authData = authenticate($_POST['userLogin'],$_POST['userPassword']))
{
// authentication passed
// renamed the variable $authData just for clarity
header("Location: authenticate.php?$authData");
die();
}
else {
// authentication failed
$error = "Login failed: Incorrect user name, password, or rights<br />";
}
Не уверен, почему у вас есть $_SESSION = array();
в login.php, но если вы хотите передать $ data с одного php на другой, просто установите его в сеансе как
$_SESSION['data'] = $data;
анг, чтобы получить его в другом файле
$data = $_SESSION['data'];