1

我想使用 LDAP 在 Active Directory 中查询包含部分字符串的组,然后显示每个组中有多少用户。

为此,我正在研究LINQ to LDAP,因为我喜欢使用 LINQ 语法。要使用此方法进行查询,第二步是设置配置并进行查询:

var config = new LdapConfiguration();
config.ConfigureFactory("serverName.intranet");
using (var context = new DirectoryContext(config))
{
   context.Log = Console.Out;

   var user = context.Query<User>()
                .Where(u => u.FirstName == "Erwin")
                .FirstOrDefault();

   Console.WriteLine(user.Group);      
}

但第一步是定义模型。这就是我卡住的地方。我更愿意定义一个Group模型和一个User模型。这样我就可以查询并获得不同的Groups. Users另一个查询是找出这样一个组中有多少和什么类型。

不幸的是,我不知道也找不到如何使用 LINQ to LDAP 设置模型。现在我有一些随机属性:

using LinqToLdap.Mapping;
using System;
using System.Security.Principal;

[DirectorySchema("CN=Users")]
public class User
{
   [DirectoryAttribute("givenName")]
   public string FirstName { get; set; }

   [DirectoryAttribute("sn")]
   public string LastName { get; set; }

   [DirectoryAttribute("physicalDeliveryOfficeName")]
   public string Office { get; set; }
}

我得到了错误:

Response=[ ErrorMessage: 000020D6: SvcErr: DSID-03100754, problem 5012 (DIR_ERRO
R), data 0
, MatchedDN: , ResultCode: OperationsError, RequestId: , Controls: , Referrals:
 ]   Message=An operation error occurred.    Data=...        InnerException={ }
     TargetSite={ }  StackTrace=   at System.DirectoryServices.Protocols.LdapCon
nection.ConstructResponse(Int32 messageId, LdapOperation operation, ResultAll re
sultType, TimeSpan requestTimeOut, Boolean exceptionOnTimeOut)
   at System.DirectoryServices.Protocols.LdapConnection.SendRequest(DirectoryReq
uest request, TimeSpan requestTimeout)
   at LinqToLdap.QueryCommands.FirstOrDefaultQueryCommand.Execute(DirectoryConne
ction connection, SearchScope scope, Int32 maxPageSize, Boolean pagingEnabled, I
LinqToLdapLogger log, String namingContext)
   at LinqToLdap.DirectoryQueryProvider.Execute(Expression expression)  HelpLink
=null   Source=System.DirectoryServices.Protocols       HResult=-2146233088

Unhandled Exception: System.DirectoryServices.Protocols.DirectoryOperationExcept
ion: An operation error occurred.
   at System.DirectoryServices.Protocols.LdapConnection.ConstructResponse(Int32
messageId, LdapOperation operation, ResultAll resultType, TimeSpan requestTimeOu
t, Boolean exceptionOnTimeOut)
   at System.DirectoryServices.Protocols.LdapConnection.SendRequest(DirectoryReq
uest request, TimeSpan requestTimeout)
   at LinqToLdap.QueryCommands.FirstOrDefaultQueryCommand.Execute(DirectoryConne
ction connection, SearchScope scope, Int32 maxPageSize, Boolean pagingEnabled, I
LinqToLdapLogger log, String namingContext)
   at LinqToLdap.DirectoryQueryProvider.Execute(Expression expression)
   at LinqToLdap.QueryProvider.Execute[TResult](Expression expression)
   at System.Linq.Queryable.FirstOrDefault[TSource](IQueryable`1 source)
   at LinqToLdap.Program.Main(String[] args) in c:\LinqToLdap\LinqToLdap\Program
.cs:line 18

我怀疑那是因为我没有DirectorySchema以正确的方式定义。有人可以帮我设置 LINQ to LDAP 模型和查询吗?

4

0 回答 0