乐趣区

关于c#:C跨PC远程调用程序并显示UI界面

在我的项目中有一个需要是须要在局域网内跨 PC 近程调用一个程序,并且要求有界面显示,考察了一些材料,能实现近程调用的.Net 技术大略有 PsExec、WMI、Schedule Task。

这三种形式都做了一个尝试,后果发现 PsExec、WMI 都只能在过程列表中看到程序执行,却无奈显示界面,无奈执行程序中的管理员权限操作,就连简略的在 C 盘创立一个 txt 文本都做不到。

兴许是我应用办法不对,无奈达到我的需要。直到起初应用了 Schedule Task 的形式之后,才胜利实现了我的需要。

第三种技术的次要思路是先通过 CMD 窗口调用 schtasks 命令在近程 PC 上创立一个单次执行的打算工作,在打算工作中调用内部程序,而后立刻执行,能够显示界面,并且能够执行管理员权限的操作。

用到的 schtasks 命令:

string queryTaskArg = string.Format(@"/query /s {0} -u domainname\{1} -p {2} /tn install", ip, username, password);
string creatTaskArg = string.Format(@"/create /s {0} -u domainname\{1} -p {2} /sc ONCE /st 10:00 /tn installSelector /tr {3} /rl HIGHEST /ru Local /IT", ip, username, password, installPath);
string runTaskArg = string.Format(@"/run /s {0} -u domainname\{1} -p {2} /tn install", ip, username, password); ;
string deleteTaskArg = string.Format(@"/delete /s {0} -u domainname\{1} -p {2} /tn install /F", ip, username, password);

schtasks /create 创立打算工作

schtasks /query 查问打算工作

schtasks /run z 执行打算工作

schtasks /delete 删除打算工作

ip:近程 PC 的 IP 地址

username:近程 PC 的登陆用户名

password:近程 PC 的登陆密码

/tn 打算工作的名字 /tr 调用程序的门路 /sc 设置执行频率 /rl 设置运行权限

须要留神的是应用这个办法近程调用程序会有相对路径方面的问题,不倡议在执行程序中应用相对路径拜访其余文件。

残缺代码:

string creatTaskArg = string.Format(@"/create /s {0} -u domainname\{1} -p {2} /sc ONCE /st 10:00 /tn installSelector /tr {3} /rl HIGHEST /ru Local /IT", ip, username, password, installSelectorPath);
                string runTaskArg = string.Format(@"/run /s {0} -u domainname\{1} -p {2} /tn installSelector", ip, username, password); ;
                string deleteTaskArg = string.Format(@"/delete /s {0} -u domainname\{1} -p {2} /tn installSelector /F", ip, username, password);
                System.Diagnostics.Process p1 = new System.Diagnostics.Process();
                p1.StartInfo.FileName = @"schtasks.exe";
                p1.StartInfo.Arguments = string.Format(@"/query /s {0} -u domainname\{1} -p {2} /tn installSelector", ip, username, password);
                p1.StartInfo.UseShellExecute = false;
                p1.StartInfo.RedirectStandardError = true;
                p1.StartInfo.RedirectStandardOutput = true;
                p1.StartInfo.CreateNoWindow = true;
                p1.Start();
                p1.WaitForExit();
                string err = p1.StandardError.ReadToEnd();
                string sop = p1.StandardOutput.ReadToEnd();
                if (!string.IsNullOrEmpty(err) && string.IsNullOrEmpty(sop))
                {
                    p1.StartInfo.Arguments = creatTaskArg;
                    p1.Start();
                    p1.WaitForExit();
                    err = p1.StandardError.ReadToEnd();
                    sop = p1.StandardOutput.ReadToEnd();
                    if (!sop.ToLower().Contains("success"))
                    {throw new Exception(string.Format("Create schedule task failed on {0}", ip));
                    }
                }
                else
                {_logger.Error(err);
                }
                p1.StartInfo.Arguments = runTaskArg;
                p1.Start();
                p1.WaitForExit();
                err = p1.StandardError.ReadToEnd();
                sop = p1.StandardOutput.ReadToEnd();
                if (!string.IsNullOrEmpty(err) || !sop.ToLower().Contains("success"))
                {throw new Exception(string.Format("Run schedule task failed on {0}", ip));
                }
                p1.StartInfo.Arguments = deleteTaskArg;
                p1.Start();
                p1.WaitForExit();
                err = p1.StandardError.ReadToEnd();
                sop = p1.StandardOutput.ReadToEnd();
                if (!string.IsNullOrEmpty(err) || !sop.ToLower().Contains("success"))
                {throw new Exception(string.Format("Delete schedule task failed on {0}", ip));
                }
                p1.Close();
退出移动版