假设我有一个接受用户名和密码的 .NET Core 控制台应用程序,该应用程序在 Linux 上运行。如何验证用户名和密码在 Windows 域 Controller (与 Linux 计算机在同一网络上运行)上是否有效?
感谢@gabriel-luci 的建议,我拼凑了这个使用 Novell.Directory.Ldap.NETStandard 的原始示例从我发现的其他人那里。
using Novell.Directory.Ldap;
using System;
namespace ConsoleApp
{
class Program
{
static void Main()
{
Console.Write("Host: ");
var dc = Console.ReadLine();
Console.Write("Domain\\User: ");
var parts = Console.ReadLine().Split("\\");
var domain = parts[0];
var user = parts[1];
Console.Write("Password: ");
var pass = Console.ReadLine();
try
{
using (var ldap = new LdapConnection { SecureSocketLayer = false })
{
ldap.Connect(dc, LdapConnection.DefaultPort);
ldap.Bind($"{user}@{domain}", pass);
if (!ldap.Bound)
{
Console.Write("Not ");
}
Console.WriteLine("Valid");
}
}
catch (LdapException e)
{
Console.WriteLine(e.Message);
}
}
}
}
当我针对在 VM 中运行的 Windows 2012 域 Controller 对其进行测试时,它在 win-x64 和 linux-arm 上运行良好。
我是一名优秀的程序员,十分优秀!