이 문서에서는 .NET에서 프로세스를 시작하려면 관리 권한이 필요하다는 일반적인 문제를 다룹니다. 제시된 솔루션은 가장을 활용하여 필요한 권한이 있는 사용자 계정으로 프로세스를 실행합니다.
다음 코드 조각은 ImpersonationHelper 클래스를 사용하여 이를 달성하는 방법을 보여줍니다(표시되지는 않았지만 필요한 가장 논리를 처리한다고 가정함).
<code class="language-csharp">System.Diagnostics.Process proc = new System.Diagnostics.Process(); System.Security.SecureString ssPwd = new System.Security.SecureString(); proc.StartInfo.UseShellExecute = false; proc.StartInfo.FileName = "filename"; proc.StartInfo.Arguments = "args..."; proc.StartInfo.Domain = "domainname"; proc.StartInfo.UserName = "username"; string password = "user entered password"; foreach (char c in password) { ssPwd.AppendChar(c); } ssPwd.MakeReadOnly(); //Important security step proc.StartInfo.Password = ssPwd; proc.Start();</code>
이 코드는 지정된 자격 증명을 사용하여 프로세스를 시작합니다. 결정적으로 비밀번호는 SecureString
을 사용하여 안전하게 처리됩니다. 적절한 오류 처리를 구현하고 사용 후 SecureString
를 올바르게 폐기하는 것을 잊지 마세요. 이 방법은 사용자 가장을 활용하여 높은 권한으로 프로세스를 실행하는 안전한 방법을 제공합니다.
위 내용은 .NET 프로세스를 다른 사용자로 실행하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!