在我拔掉剩下的头发之前,我想对此有所了解 我正在尝试获取文件夹的所有权。我当然是以管理员身份运行程序,因为我可以更改资源管理器中的所有者,所以我有权获得所有权。
如果管理员或我的帐户拥有它,我可以更改所有者,如果我已拥有所有权,我可以更改权限。
如果我试图给自己一个文件的所有权,让我说由SYSTEM拥有,那么我得到一个unauthorizedexception。
我用accesscontrol方法尝试了一些不同的东西,但没有任何效果,我认为这个最新的方法直接来自本书。
private static void makePerm(string file, NTAccount account)
{
FileInfo finfo = new FileInfo(file);
FileSecurity fsecurity = finfo.GetAccessControl();
//also tried it like this //fsecurity.ResetAccessRule(new FileSystemAccessRule(string.Format(@"{0}\{1}", Environment.UserDomainName.ToString(), Environment.UserDomainName.ToString()), FileSystemRights.FullControl, AccessControlType.Allow));
fsecurity.SetOwner(account);
finfo.SetAccessControl(fsecurity);
}
我在Windows 7上尝试这个。顺便说一句 我在这里缺少什么?
答案 0 :(得分:10)
我遇到了同样的问题,只是在这里张贴给其他可能像我一样来这里搜索的人:
您需要在Luke上面提到的代码中明确启用SeTakeOwnershipPrivilege。我发现这个Process Privileges对于处理这类事情非常有帮助。
以下是修复我的代码的方法:
using System;
using System.Diagnostics;
// ...
using (new ProcessPrivileges.PrivilegeEnabler(Process.GetCurrentProcess(), Privilege.TakeOwnership))
{
directoryInfo = new DirectoryInfo(path);
directorySecurity = directoryInfo.GetAccessControl();
directorySecurity.SetOwner(WindowsIdentity.GetCurrent().User);
Directory.SetAccessControl(path, directorySecurity);
}
答案 1 :(得分:1)
您是否先通过UAC提升了流程?在Windows 7上,如果没有UAC升级,您的进程将使用较低权限的令牌运行。