حدث ذلك أن الحملة الكبيرة (نسبيًا) لديها العديد من المكاتب البعيدة مع عدد لائق من المستخدمين. ترتبط جميع المكاتب بالشبكة نفسها ذات نطاق مشترك ، وقد تم تعريف كل مكتب في Active Directory (يشار إليه فيما بعد باسم AD) كوحدة تنظيمية (OU) ، حيث تم إنشاء المستخدمين بالفعل.كان من الضروري منح المستخدمين الفرصة بسرعة ودون بذل الكثير من الجهد للحصول على معلومات الاتصال للموظف الضروري من م ، ومسؤولي النظام للتحرر من روتين تحرير ملف نصي لعب دور دفتر العناوين.لم تكن هناك خيارات مناسبة جاهزة لحل المهمة ، لذلك كان علي أن أفعل كل شيء بيدي ورأسي.بادئ ذي بدء ، تحتاج أولاً إلى تحديد ما ستستخدمه ، الأمر بسيط - يجب أن يكون الدليل النهائي متاحًا لجميع مستخدمي المجال من خلال متصفح. أول ما يتبادر إلى الذهن هو PHP بالاقتران مع ldap ، وسوف نستخدمها. أكبر ميزة لاستخدام PHP ، أعتقد أن بساطتها النسبية ، هي أن أي شخص لديه القليل من الفهم لمسؤول النظام يمكنه إجراء التغييرات اللازمة على التعليمات البرمجية ، إذا لزم الأمر ، دون إجهاد بشكل خاص.لذا ، لنبدأ. أولاً ، لنقم بتعيين معلمات اتصال المجال:$srv ="SERVER";
$srv_domain ="DOMAIN.COM";
$srv_login ="USERNAME@".$srv_domain;
$srv_password ="PASSWORD";
النقطة التالية هي تحديد الوحدة التنظيمية التي سنبحث فيها عن المستخدمين. سنقوم بذلك عن طريق اعتراض القيم من $ _GET ['place']. على سبيل المثال ، إذا انتقل المستخدم إلى server / 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 التي سوف ابحث عن المستخدمين أم لا. إذا لم تكن هناك تطابقات مدرجة في "حالة التبديل" ، فعندئذٍ يكون $ 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:
a:hover{text-decoration: underline; color:
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;}
.smalltext{padding-top: 1px;
padding-bottom: 1px;
text-align: bottom;
font-family:tahoma;
color:
line-height: 7px;
font-size: 10px;}
.smalltext:hover{color:
.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);}
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>
";
نحدد مرشحات البحث عن طريق م ، والحصول على بيانات حول الوحدة التنظيمية:$filter ="(&(objectcategory=user)(!(userAccountControl:1.2.840.113556.1.4.803:=2)))";
$filter2 ="(objectCategory=OrganizationalUnit)";
$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];
$PlaceAddres = $placeinfo[0]["street"][0];
$PlaceMail = $placeinfo[0]["description"][0];
$PlacePhone = $placeinfo[0]["st"][0];
بعد ذلك ، ارسم أعلى الصفحة: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>";
بعد ذلك ، نحصل على بيانات المستخدم ونعالجها في حلقة ، ومن أجل إخفاء بعض حسابات (على سبيل المثال ، الخدمة) ، نحدد ببساطة "إخفاء" في حقل "الغرفة" في تفاصيل المستخدم في م ، ولن يتم عرض هؤلاء المستخدمين في الدليل: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];
if (!$UserMail)) $UserMail = "-";
$UserIpPhone = $info[$i]["ipphone"][0];
if (!$UserIpPhone) $UserIpPhone = "-";
$UserMobile = $info[$i]["mobile"][0];
if (!$UserMobile) $UserMobile = "-";
وبالمناسبة، إذا كنت بحاجة للحصول على قيمة سمة أخرى، ثم تذكر (وهذا هو المهم):في طلب نعبر اسم السمة في أقل حالة ، وإلا فإنه لن ينجح.ونلصق البيانات المستلمة في الجدول: 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>";
else echo "-";
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>
إذا كان الرمز الخاص بي يساعد شخصًا ما - فسأكون سعيدًا باستخدامه!يمكنك أيضًا تحريرها بحرية كما يحلو لك (تحسين / تدهور) وتوزيعها بأي طريقة.شكرا للانتباه!