恩,C#表現也不錯,看來確實是一個比較簡單的命令而已,如果你沒有運行 一下這兩個程序,你可能以為這樣就搞定了,相當簡單。但是如果你是一個細心 的人,或者你是用過runas命令行的話,你應該知道,這裡有問題:
很可惜的是,這兩種方式存在一個致命的缺陷:只能在第一個命令行中輸入 用戶名,然後才會由系統提示輸入密碼,這樣就不能在一條命令行中將用戶名和 密碼完全包含。這樣我們只能使用代碼實現一半,另外一半則仍然需要手動輸入 (密碼)——顯然這就造成了一個半拉子工程。我們也可以查看一下runas幫助 說明:
這樣設計的目的在於防止像我們這種弱弱的想要使用命令行來提高運行程序 的權限的人——至少我們是不能使用批處理文件來干這件事了,這樣更安全了, 不是嗎?好吧,接下來,我們將使用另外一種方法,這種方法則不會出現上述半 拉子工程的尴尬情況。
3, 使用Process的ProcessStartInfo實現
ProcessUserLogonHelper
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Diagnostics;
namespace MainTest
{
class ProcessUserLogonHelper
{
/// <summary>
/// 在Main函數中調用該方法的的示例代碼
/// </summary>
private void InvokeExample()
{
ProcessUserLogonHelper phelper = new ProcessUserLogonHelper();
Process pro = phelper.CreateProcessWithUserToken(@"C:\Program Files\Internet Explorer\IExplore.exe", "bestreme.com", "chdwu", "************");
pro.Start();
}
/// <summary>
/// 使用指定帳戶綁定進程
/// </summary>
/// <param name="appPath">進程的宿主程序 </param>
/// <param name="domain">指定帳戶的域名 </param>
/// <param name="userName">指定帳戶的用戶名 </param>
/// <param name="passWord">指定帳戶的密碼 </param>
/// <returns>綁定了特定帳戶的進程 </returns>
public Process CreateProcessWithUserToken(string appPath,string domain, string userName, string passWord)
{
Process pro = new Process();
ProcessStartInfo processInfo = new ProcessStartInfo(appPath);
processInfo.UseShellExecute = false;
processInfo.UserName = userName;
processInfo.Domain = domain;
System.Security.SecureString psw = new System.Security.SecureString();
foreach (char c in passWord.ToCharArray ())
{
psw.AppendChar(c);
}
processInfo.PassWord = psw;
processInfo.WorkingDirectory = System.IO.Path.GetDirectoryName(appPath);
pro.StartInfo = processInfo;
return pro;
}
/// <summary>
/// 使用指定帳戶綁定進程
/// </summary>
/// <param name="appPath">進程的宿主程序 </param>
/// <param name="userName">指定本地帳戶的用戶 名</param>
/// <param name="passWord">指定帳戶的密碼 </param>
/// <returns>綁定了特定帳戶的進程 </returns>
public Process CreateProcessWithUserToken(string appPath, string userName, string passWord)
{
return CreateProcessWithUserToken(appPath, "", userName, passWord);
}
}
}