0

假设我有一个接受用户名和密码的 .NET Core 控制台应用程序,该应用程序在 Linux 上运行。如何验证用户名和密码在 Windows 域控制器上是否有效(与 Linux 机器在同一网络上运行)?

4

1 回答 1

1

感谢@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 域控制器进行测试时,它在 win-x64 和 linux-arm 上运行良好。

在此处输入图像描述

于 2019-09-25T07:27:27.500 回答