OrionXL

Телефонный справочник или список сотрудников на C# для sharepoint foundatation 2010 с использованием AD (active directory)

Роман Иванов @ 11:56 06.03.2011

В данной статье Вы узнаете, как работать с AD (active directory), создать простой телефонный справочник или справочник сотрудников на языке программирования C# для системы sharepoint foundatation 2010 и инструмента разработчика Microsoft Visual Studio 2010.

Данные о Windows пользователях, уровнях доступа (правах) обычно хранятся в AD. Согласитесь, поэтому самым оптимальным, централизованным, оперативным (если пользователь получил доступ в корпоративную сеть, то он автоматически появляется в AD) способом хранить и получать информацию о пользователях и соответственно  сотрудниках можно из Active Directory.

Так же если у Вас стоит корпоративный портал Sharepoint, то с помощью него можно организовать удобный и простой, но очень мощный инструмент – телефонный справочник сотрудников или (и) справочник сотрудников.

Задачи, решаемые этим компонентом:

1. Поиск сотрудников по (части слова) инициалам, телефонному номеру, отделу и т.д.

2. Поиск по буквенному каталогу

3. Поиск по организационной структуре

Итак, более подробную информацию об AD Вы можете найти в интернете, в AD можно хранить любую символьную информацию – обычно здесь хранится учетная запись, ФИО, фамилия, отдел, телефон, e-mail, уровень прав на доступ, офис, так же сюда можно добавить – ФИО руководителя, адрес организации, фотографию (ссылку) и т.д.

Есть один способ оптимизировать вывод информации об отделах: сделать функцию static  и включить кеширование.

Как Вы, наверное, догадались, при поиске по строке запроса, мы будем искать фамилию или имя, или номер в директории и выводить информацию на экран.

Поиск по каталогу реализуется очень просто. Создаем список букв от (А до Я) и по нажатию на каждую букву ловим letter=querystring(letter) и создаем запрос к Active Directory в форме: filter = “ (&(ObjectClass=User)(family=”+letter+”*))”  и выводим получившийся результат в строку либо с помощью SPGrid или другого инструмента :-)

Для работы с организационной структурой удобнее будет запомнить ее в список с иерархией элементов и делать к ней запрос, т.к. структура организации меняется не так часто в отличие от сотрудников J

Наслаждаемся :-)
VisualWebPart1UserControl.ascx.cs

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
using System;
using System.Web.UI;
using System.Web.UI.WebControls;
using System.Web.UI.WebControls.WebParts;
using System.DirectoryServices;
using Microsoft.SharePoint;
using Microsoft.SharePoint.Linq;
using System.Linq;
using System.Collections.Generic;
 
namespace showADusers.VisualWebPart1
{
    public partial class VisualWebPart1UserControl : UserControl
    {
        protected void Page_Load(object sender, EventArgs e)
        {
        }
 
        protected override void Render(HtmlTextWriter writer)
        {
            writer.WriteLine("Поиск пользователей компании*");
            writer.WriteBreak();
            base.Render(writer);
 
            writer.WriteBreak();
            DirectorySearcher(writer); // Выводим результат поиска
            writer.WriteBreak();
        }
 
        public string keyfilter="";
 
        public void DirectorySearcher(HtmlTextWriter writer)
        {
 
            keyfilter = textBox1.Text;
            if(keyfilter!="")
            SPSecurity.RunWithElevatedPrivileges(delegate() // даже анонимные пользователи могут смотреть результат кода
            {
                try
                {
                    string strrootdse = objsearch.SearchRoot.Path; // работаем с AD  смотри документацию от  Microsoft
                    string  strrootdse = "LDAP://мой сервер LDAP";
                    DirectoryEntry objdirentry = new DirectoryEntry(strrootdse);
 
                    DirectorySearcher objsearch = new DirectorySearcher(objdirentry);
 
                    string query = "(& (cn=*" + keyfilter + "*)(objectClass=user))"; // ставим фильтр поиска
                    objsearch.Filter = query;
 
                    objsearch.PropertiesToLoad.Add("cn");
                    objsearch.PropertiesToLoad.Add("title");
                    objsearch.PropertiesToLoad.Add("physicaldeliveryofficename");
                    objsearch.PropertiesToLoad.Add("department");
                    objsearch.PropertiesToLoad.Add("company");
 
                    objsearch.PropertyNamesOnly = true;
 
                    objsearch.Sort.Direction = System.DirectoryServices.SortDirection.Ascending;
 
                    objsearch.Sort.PropertyName = "cn";
 
                    SearchResultCollection colresults = objsearch.FindAll();
                    // выведем реультат
                    foreach (SearchResult objresult in colresults)
                    {
                        writer.Write(objresult.GetDirectoryEntry().Properties["cn"].Value+" | ");
                        writer.Write(objresult.GetDirectoryEntry().Properties["title"].Value +" | ");
                        writer.Write(objresult.GetDirectoryEntry().Properties["physicaldeliveryofficename"].Value+" | ");
                        writer.Write(objresult.GetDirectoryEntry().Properties["department"].Value+" | ");
                        writer.Write(objresult.GetDirectoryEntry().Properties["company"].Value +" | ");
                        writer.Write("
");
                    }
 
                    objsearch.Dispose();
                }
                catch { };
 
            });
 
        }
 
       }
 
    }
}

VisualWebPart1UserControl.ascx

1
2
3
4
5
6
7
8
9
10
11
12
<%@ Assembly Name="$SharePoint.Project.AssemblyFullName$" %>
<%@ Assembly Name="Microsoft.Web.CommandUI, Version=14.0.0.0, Culture=neutral, PublicKeyToken=71e9bce111e9429c" %>
<%@ Register Tagprefix="SharePoint" Namespace="Microsoft.SharePoint.WebControls" Assembly="Microsoft.SharePoint, Version=14.0.0.0, Culture=neutral, PublicKeyToken=71e9bce111e9429c" %>
<%@ Register Tagprefix="Utilities" Namespace="Microsoft.SharePoint.Utilities" Assembly="Microsoft.SharePoint, Version=14.0.0.0, Culture=neutral, PublicKeyToken=71e9bce111e9429c" %>
<%@ Register Tagprefix="asp" Namespace="System.Web.UI" Assembly="System.Web.Extensions, Version=3.5.0.0, Culture=neutral, PublicKeyToken=31bf3856ad364e35" %>
<%@ Import Namespace="Microsoft.SharePoint" %>
<%@ Register Tagprefix="WebPartPages" Namespace="Microsoft.SharePoint.WebPartPages" Assembly="Microsoft.SharePoint, Version=14.0.0.0, Culture=neutral, PublicKeyToken=71e9bce111e9429c" %>
<%@ Control Language="C#" AutoEventWireup="true" CodeBehind="VisualWebPart1UserControl.ascx.cs" Inherits="showADusers.VisualWebPart1.VisualWebPart1UserControl" %>
 
Введите ФИО полностью или частично (пример: Роман Иванов)
<asp:TextBox ID="textBox1" runat="server" Width="256px" ></asp:TextBox>
<asp:Button ID="button1" Text="Найти" runat="server" />

Комментариев нет

Комментариев нет.

RSS-лента комментариев к этой записи.

Извините, обсуждение на данный момент закрыто.

алгоритмы, методы, программы - OrionXL