4

我正在使用 C# 库连接到 vSphere (VimClient)。我使用这种方法登录:

VimClient client = new VimClient();
client.Connect("https://vSphereMachine/sdk");
client.Login("userName", "password");

我登录的用户是进程使用的当前用户。有没有办法可以使用当前登录的用户进行身份验证?

该线程似乎提供了建议,但我在那里尝试的没有任何效果:http: //communities.vmware.com/message/1125103

这可能是因为我不熟悉 .NET 中的 SSPI 实现。

4

1 回答 1

1

由于VMWare.Vim.dll只是包装了生成的 WCF 服务客户端,我能够使这个示例项目适应直接使用 dll。这是我对他LoginBySspiPackage方法的改编。

    private UserSession LoginBySspiPackage(SspiPackageType sspiPackage, string serviceSpn)
    {
        Log($"Logging in to VSphere instance {VimClient.ServiceUrl} using SSPI.");
        var sspiClient = new SspiClient(serviceSpn, sspiPackage);
        var sessionManager = new SessionManager(VimClient, VimClient.ServiceContent.SessionManager);

        var serverNotReady = true;
        UserSession session = null;

        while (serverNotReady)
        {
            try
            {
                var base64String = Convert.ToBase64String(sspiClient.Token);
                session = sessionManager.LoginBySSPI(base64String, "en");

                serverNotReady = false; // Connected!  
            }
            catch (VMware.Vim.VimException e)
            {
                if (e.MethodFault is SSPIChallenge)
                {
                    var sspiChallenge = e.MethodFault as SSPIChallenge;
                    var base64String = Convert.FromBase64String(sspiChallenge.Base64Token);
                    sspiClient.Initialize(base64String);
                }
                else if (e.MethodFault is InvalidLogin)
                {
                    throw new InvalidLoginException(e.Message);
                }
                else
                {
                    throw;
                }
            }
        }

        return session;
    }
于 2017-03-20T21:56:43.643 回答