0

这是我构建 .bat 文件并运行它的代码。

StringBuilder Batch = new StringBuilder();
Batch.AppendLine("@echo off");
Batch.AppendLine("taskkill /IM " + Process.GetCurrentProcess().ProcessName + ".exe /F");
Batch.AppendLine("ping localhost > nul");
Batch.AppendLine("del /f " +  (char)34 + Application.ExecutablePath + (char)34);
Batch.AppendLine("ren " + (char)34 + Application.StartupPath + @"\update.exe" + (char)34 + " " + Process.GetCurrentProcess().ProcessName);
Batch.AppendLine((char)34 + Application.ExecutablePath + (char)34);
Batch.AppendLine("del %0");

File.WriteAllText(Application.StartupPath + @"\update.bat", Batch.ToString(), Encoding.Default);
        Process.Start(Application.StartupPath + @"\update.bat");

但是,我的访问被拒绝,我必须以管理员身份运行它,我该怎么做?

4

1 回答 1

0

不是你的问题的答案,但我认为你没有从最好的方向接近它。相反,请参阅这个问题,它为您实际尝试做的事情提供了一个非常可靠的答案:what-is-the-best-way-to-auto-update-a-windows-application

TL;DR 如果您的原始安装是“所有用户”,那么您将遇到手动提升权限的问题。如果安装是“每个用户”,那么这简化了权限问题。

于 2013-08-12T23:13:25.827 回答