4

我有一个Process.Start在我的 Windows 7 Professional 64 位开发机器上失败的方法的实现,同时在我们的 Windows 2008 测试环境中工作。

const string CommandDirectory = @"C:\Program Files (x86)\Command";

var process = new Process
{
    StartInfo =
    {
        FileName = string.Format("{1}{0}MyExecutable.exe", Path.DirectorySeparatorChar, CommandDirectory),
        RedirectStandardError = true,
        RedirectStandardOutput = true,
        UseShellExecute = false,
        UserName = userName,
        Password = securePassword,
        Domain = "MYDOMAIN",
    },
};

process.Start();

process.Start();,我的开发机器上出现以下异常:

System.ComponentModel.Win32Exception occurred
  HResult=-2147467259
  Message=The directory name is invalid
  Source=System
  ErrorCode=-2147467259
  NativeErrorCode=267
  StackTrace:
       at System.Diagnostics.Process.StartWithCreateProcess(ProcessStartInfo startInfo)
       at System.Diagnostics.Process.Start()
  InnerException: 

我尝试了几件事:

  1. 我已确保分配给进程的用户帐户对可执行文件所在的路径以及 %systemroot% 位置具有完全权限。我还确保用户在本地安全策略中具有“身份验证后模拟客户端”权限。

  2. 我已经尝试明确设置ProcessStartInfo.WorkingDirectoryCommandDirectory. 当我这样做时,可执行文件启动但立即崩溃,没有解释。

  3. 我通过删除 、 和 属性在我的开发机器上创建了此功能,UserName以便PasswordDomain使用我的个人凭据。但这对于部署是不切实际的。这让我觉得问题与凭据和权限有关。

谁能告诉我我做错了什么?

4

1 回答 1

1

@Julien Lebosquain 的评论让我找到了答案。我需要以我想模拟的用户身份在本地登录一次。这创建了默认用户文件夹。

据推测,我调用的可执行文件需要写入 AppData 或用户目录的另一个子文件夹。

于 2014-03-17T19:23:21.420 回答