PHP + LDAP WEB հասցեների գրացուցակի ստեղծում

Այդպես եղավ, որ (համեմատաբար) մեծ քարոզարշավն ուներ բազմաթիվ հեռավոր գրասենյակներ՝ արժանապատիվ թվով օգտատերերով: Բոլոր գրասենյակները միացված են մեկ ցանցի՝ ընդհանուր տիրույթով, յուրաքանչյուր գրասենյակ Active Directory-ում (այսուհետ՝ AD) սահմանվել է որպես Կազմակերպչական միավոր (OU), որում արդեն ստեղծվել են օգտվողներ:

Անհրաժեշտ էր օգտատերերին հնարավորություն տալ արագ և առանց ջանքերի ստանալ AD-ից պահանջվող աշխատակցի կոնտակտային տվյալները, իսկ համակարգի ադմինիստրատորներին ազատել հասցեագրքի դեր կատարող տեքստային ֆայլի խմբագրման ռեժիմից:

Խնդիրը լուծելու պատրաստի հարմար տարբերակներ չկային, ուստի ամեն ինչ պետք է անեի իմ ձեռքերով ու գլխով։

Սկսենք նրանից, որ նախ պետք է որոշել, թե ինչ օգտագործել, դա պարզ է՝ վերջնական գրացուցակը պետք է հասանելի լինի տիրույթի բոլոր օգտագործողներին բրաուզերի միջոցով: Առաջին բանը, որ գալիս է մտքին, PHP-ն է ldap-ի հետ համատեղ, և մենք կօգտագործենք դրանք: PHP-ի օգտագործման մեծ առավելությունը ես համարում եմ նրա հարաբերական պարզությունը. ցանկացած համակարգի ադմինիստրատոր թեկուզ մի փոքր ըմբռնումով կկարողանա անհրաժեշտ փոփոխություններ կատարել կոդում, անհրաժեշտության դեպքում, առանց առանձնապես լարվելու:

Այսպիսով, եկեք սկսենք: Նախ, եկեք սահմանենք տիրույթին միանալու պարամետրերը.

$srv ="SERVER";
$srv_domain ="DOMAIN.COM";
$srv_login ="USERNAME@".$srv_domain; 
$srv_password ="PASSWORD";

Հաջորդ կետը որոշելն է, թե որ OU-ում ենք մենք փնտրելու օգտվողներին: Մենք դա կանենք՝ ընդհատելով $_GET['place'] արժեքները: Օրինակ, եթե օգտվողը գնում է հասցեով սերվեր/index.php?place=առաջին, ապա փոփոխականը $տեղ կհատկացվի արժեքը առաջին.

$place = (@$_GET['place']);
$doscript=true;
switch($place){ 
case "first" :
	$dn ="OU=ou1,OU=DOMAIN,dc=DOMAIN,dc=COM";			
	break;
case "second":
	$dn ="OU=ou2,OU=DOMAIN,dc=DOMAIN,dc=COM";			
	break;
	//здесь можно добавить ещё условий.
default:
	$doscript=false; 
	break;
}
if (!$doscript) include "main_table.html";

Փոփոխական $doscript անհրաժեշտ է արժեքը պահելու համար՝ արդյոք մենք սահմանել ենք OU-ը, որում մենք փնտրելու ենք օգտվողներ, թե ոչ: Եթե ​​«switch-case»-ում թվարկված համընկնումներ չկան, ապա $doscript=false, սկրիպտի հիմնական մասը չի կատարվի, և կցուցադրվի «main_table.html» մեկնարկային էջը (ես ձեզ կասեմ դրա մասին. դա ամենավերջում):

Եթե ​​մենք սահմանել ենք OU, ապա մենք անցնում ենք հետագա գործողությունների. մենք սկսում ենք գրացուցակի էջ նկարել օգտվողի համար.

else if ($doscript) {
{echo "
<!DOCTYPE html> 
<html xmlns='http://www.w3.org/1999/xhtml'>
<head>
<link rel='shortcut icon' href='ico.png'>
<meta charset='windows-1251/ '>

Մենք ներառում ենք ոճեր ավելի հաճելի տեսք ունենալու համար (այո, դրանք կարող են ներառվել որպես css ֆայլ, բայց IE-ի որոշ տարբերակներ չեն ցանկանում ընդունել այս ձևով սահմանված ոճերը, այնպես որ դուք պետք է դրանք ուղղակիորեն գրեք սցենարի մեջ).

<style>
	*{text-align: center; font-family:tahoma; font-size:14px;}
	a{text-decoration: none; color: #000;}
	a:hover{text-decoration: underline; color: #0059FF;}
	#bold{text-decoration: none; font-weight: 600;font-size:20px;}
	#table,tr,td{border-style:solid;border-width:1px;	border-collapse:collapse;padding:5px; height:22px;border-color:#7d7d7d;}
	/* Нечетные строки */#table tbody tr:nth-child(odd){background: #fff;}
	/* Четные строки */   #table tbody tr:nth-child(even){background: #F7F7F7;}	
	#noborder{border-width: 0 px; border-style: none;}	
	#sp30px{text-indent: 30px;text-align: justify;}
	#smallsize{font-family:tahoma; text-indent: 5px; text-align:left; font-size:12px;}
	#top {background: #ffffff;
		text-align: center;
		left:0;
		top:0px;
		table-layout: fixed;
		border-style:solid;
		border-width:0px;
		border-collapse:collapse;
		padding:0px;
		height:22px;
		border: 0px;
		z-index: 99999;
		display:block;
		width:80px;
		opacity: 0.6;
		filter: alpha(Opacity=60);
		height:100%;
		position:fixed;}
	#top:hover{background: #afafaf;opacity: 100;filter: alpha(Opacity=100);text-decoration: none;color: #000000;}
	.smalltext{padding-top: 1px;
		padding-bottom: 1px;
		text-align: bottom;
		font-family:tahoma;
		color: #a0a0a0;
		line-height: 7px;
		font-size: 10px;}
	.smalltext:hover{color: #0000ff;}		
	.transition-rotate {position: relative;
		z-index: 2;
		margin: 0 auto;
		padding: 5px;
		text-align: center;
		max-width: 500px;
		cursor: pointer;
		transition: 0.1s linear;}
	.transition-rotate:hover {-webkit-transform: rotate(-2deg);	transform: rotate(-2deg);}
	#lineheight{
		text-align: left;
		line-height: 1px;
		text-decoration: none;
		font-weight: 600;
		font-size:20px;}
</style>

Մենք ավարտեցինք ոճերը, այժմ մենք գրում ենք ներդիրի վերնագիրը և գծում ենք հարմար հղում գլխավոր էջ վերադառնալու համար.

<title>Adressbook of «YourMegaCompanyName»</title>	
</head>
<body style='background-color:#ffffff;'>";
}
echo "
<table id='top'><tr><td id='top'>
<a href='index.php?place=main' id='top' >
<br><br><br>
<img src='back_to_main.png' alt='' border='0' width='75' height='60'/>
<p>На главную</p></a>
</td></tr></table>
";

Մենք սահմանում ենք որոնման զտիչներ ըստ AD-ի և ստանում ենք տվյալներ OU-ի մասին.

$filter ="(&(objectcategory=user)(!(userAccountControl:1.2.840.113556.1.4.803:=2)))"; //все пользователи, кроме отключенных.
$filter2 ="(objectCategory=OrganizationalUnit)"; // для получения информации о OU
$ds=ldap_connect($srv);   
if ($ds) { 
    $r=ldap_bind($ds,$srv_login,$srv_password);;     
	ldap_set_option($ds,LDAP_OPT_REFERRALS, 0);
	ldap_set_option($ds,LDAP_OPT_PROTOCOL_VERSION,3);
	$sr=ldap_search($ds,$dn ,$filter );   
    ldap_sort($ds,$sr, "givenname");
    $info = ldap_get_entries($ds, $sr); 
    $sr2=ldap_search($ds,$dn ,$filter2 );   
    $placeinfo = ldap_get_entries($ds, $sr2); 
$PlaceName = $placeinfo[0]["l"][0];  			// name of place
$PlaceAddres = $placeinfo[0]["street"][0];		// address of place
$PlaceMail = $placeinfo[0]["description"][0]; 	// mail of place
$PlacePhone = $placeinfo[0]["st"][0]; 		// phone of plase

Հաջորդը մենք ձևավորում ենք էջի վերևը.

echo"<table align='center' height = '80'>
	<td id='noborder' ><div id='lineheight'>". $PlaceName ."</div></td></tr>
	<tr><td id='noborder' >". $PlaceAddres ."</td></tr>
    </table>
<table align='center' id='table'>
	<tr><td width='35' bgcolor = #f0f0e4>  № </td>
	<td width='300' bgcolor = #f0f0e4> Name </td>
	<td width='250' bgcolor = #f0f0e4> E-mail </td>
	<td width='60' bgcolor = #f0f0e4> Phone </td>
	<td width='150' bgcolor = #f0f0e4> Mobile </td></tr>
	<tr><td></td><td> Данные OU </td><td>";
echo "<div class='transition-rotate'><a href=mailto:" . $PlaceMail .">" . $PlaceMail ." </a></div>";
echo "</td><td width='150'> " . $PlacePhone ." </td><td> - </td></tr>";

Այնուհետև մենք ստանում և մշակում ենք օգտատիրոջ տվյալները օղակաձև, մինչդեռ որոշ (օրինակ՝ ծառայության) հաշիվները թաքցնելու համար մենք պարզապես մուտքագրում ենք «թաքցնել» «սենյակ» դաշտում՝ օգտատիրոջ տվյալները AD-ում, այդպիսի օգտվողներ չեն լինի: գրացուցակում ցուցադրված՝

for ($i=0; $i<$info["count"];$i++) { 
$UserHide = $info[$i]["physicaldeliveryofficename"][0];
if ($UserHide != 'hide') {
$UserName = $info[$i]["cn"][0];                //Имя пользователя
$UserPosition = $info[$i]["title"][0]; 		// Должность
$UserMail = $info[$i]["mail"][0];			//mail
if (!$UserMail)) $UserMail = "-";                  //если нет данных о ящике в AD, то отображаем прочерк
$UserIpPhone = $info[$i]["ipphone"][0];		//ip phone
	if (!$UserIpPhone) $UserIpPhone = "-";    //если нет данных о ящике в AD, то отображаем прочерк
$UserMobile = $info[$i]["mobile"][0];		//mobile
	if (!$UserMobile) $UserMobile = "-";     //если нет данных о ящике в AD, то отображаем прочерк

Ի դեպ, եթե ձեզ անհրաժեշտ է ստանալ մեկ այլ հատկանիշի արժեքը, ապա հիշեք (սա կարևոր է).
հարցումում մենք փոխանցում ենք հատկանիշի անունը փոքրատառ նամակներ, այլապես չի ստացվի։

Եվ ստացված տվյալները տեղադրեք աղյուսակում.

    echo "<tr>
	<td>". $n+=1 ."</td>
	<td> ". $UserName ."<br> <div class='smalltext'>". $UserPosition ."</div></td><td>"; //	Имя пользователя и должность 
	if ($UserMail !='-') echo "<div class='transition-rotate'><a href=mailto:'$UserMail'>$UserMail  </a></div>";    // если у пользователя есть e-mail создаём ссылку на отправку письма
	else echo "-"; //если нет e-mail - ставим прочерк.
 	echo "<td> ". $UserIpPhone ." </td>
 	<td> ". $UserMobile ." </td></tr>";
	}
}
echo "</table>";

Հաջորդը, մենք փակում ենք ldap կապը կամ ցուցադրում ենք հաղորդագրություն սերվերին միանալու անհնարինության մասին.

ldap_close($ds); 
} 
else echo "<h4>Unable to connect to LDAP server</h4>"; 
echo '<br><br><br></body></html>';}

Ներսից «main_table.html» ֆայլը պարզ html էջ է՝ հղումներով և ունի հետևյալ տեսքը.

<head>
<link rel="shortcut icon" href="ico.png"/>
<meta charset="windows-1251"/>
<title>Adressbook of «YourMegaCompanyName»</title>
</head>
<body style='background-color:#ffffff;'>
<center><a href=index.php><IMG border="none" src="logo.png"/></a></center>
<center><b>Places and offices</b></center>
<br>
<table border="0" width="450" bgcolor="#dddddd" align="center" valign="middle" CELLSPACING="0">

<tr id="space"><td></td></tr>
<tr><td align="left" id="abz"><a href="index.php?place=ou1">OU1</a></td></tr>
<tr id="space"><td></td></tr>
<tr><td align="left" id="abz"><a href="index.php?place=ou2">OU2</a></td></tr>

</table></body></html>

Եթե ​​իմ կոդը օգնի որևէ մեկին, ես ուրախ կլինեմ, օգտագործեք այն:

Դուք կարող եք նաև ազատորեն խմբագրել այն, ինչպես ցանկանում եք (բարելավել/վատացնել) և ցանկացած միջոցով տարածել այն։

Շնորհակալություն ձեր ուշադրության համար:

Source: www.habr.com

Добавить комментарий