微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

c# – 从WMI运行exe时的网络认证

我有一个需要使用WMI运行并访问网络共享的C#exe.但是,当我访问该共享时,我得到一个UnauthorizedAccessException.如果我直接运行exe,可以访问该共享.在这两种情况下,我都使用相同的用户帐户.

我的应用程序有两个部分,一个在本地PC上运行的GUI客户端和在远程PC上运行的后端进程.当客户端需要连接到后端时,首先使用WMI启动远程进程(代码如下).远程进程执行了许多操作,包括使用Directory.GetDirectories()访问网络共享并将其报告回客户端.

当客户端使用WMI自动启动远程进程时,无法访问网络共享.但是,如果我使用远程桌面连接到远程计算机并手动启动后端进程,则访问网络共享成功.

在WMI呼叫中指定的用户和远程桌面会话登录用户是一样的,所以权限应该是一样的,不是吗?

我在MSDN条目中看到Directory.Exists(),它指出“Exists方法不执行网络身份验证.如果您查询现有的网络共享而不进行预认证,则Exists方法将返回false.我假设这是相关的?如何确保用户在WMI会话中正确验证?

Connectionoptions opts = new Connectionoptions();

opts.Username = username;
opts.Password = password;

ManagementPath path = new ManagementPath(string.Format("\\\\{0}\\root\\cimv2:Win32_Process",remoteHost));

ManagementScope scope = new ManagementScope(path,opts);

scope.Connect();

ObjectGetoptions getopts = new ObjectGetoptions();
using (ManagementClass mngClass = new ManagementClass(scope,path,getopts))
{
    ManagementBaSEObject inParams = mngClass.getmethodParameters("Create");
    inParams["CommandLine"] = commandLine;
    ManagementBaSEObject outParams = mngClass.InvokeMethod("Create",inParams,null);
}

解决方法

遵循以上Isalamon建议的链接(感谢)我遵循Jestro的建议,并使用psexec.exe(可以从 http://technet.microsoft.com/en-us/sysinternals/bb897553.aspx下载)而不是WMI重写.感觉像这样一个肮脏的做法,但它似乎工作.

遇到类似问题的任何人的新代码

Process proc = new Process();
proc.StartInfo.FileName = "PsExec.exe";
proc.StartInfo.Arguments = string.Format("\\\\{0} -d -u {1}\\{2} -p {3} {4}",remoteHost,domain,username,password,commandLine);
proc.StartInfo.CreateNowindow = true;
proc.StartInfo.UseShellExecute = false;
proc.Start();

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐