在Windows中创建/打开带有读数的目录

本文关键字:Windows 创建 | 更新日期: 2023-09-27 18:36:17

我想使用活动目录用户凭据创建目录,只有该用户有权进行目录操作,例如打开列表文件,读取文件等。

 public void CreateDirectory(int value)
    {
        string drive = Directory.GetDirectoryRoot(HostingEnvironment.ApplicationPhysicalPath);
        string path = "D://" + "4524l";
        DirectoryInfo dinfo = Directory.CreateDirectory(path);
        string domainAndUsername = "456456.com" + @"'" + "guserone";
        DirectoryEntry entry = new DirectoryEntry("LDAP://124.com", domainAndUsername, "a55in123*");

        //Bind to the native AdsObject to force authentication.
        object obj = entry.NativeObject;
        DirectorySearcher search = new DirectorySearcher(entry);
        search.Filter = "(SAMAccountName=" + "guserone" + ")";
        search.PropertiesToLoad.Add("cn");
        SearchResult result = search.FindOne();   
        DirectorySecurity myDirectorySecurity = dinfo.GetAccessControl();
        //myDirectorySecurity.SetOwner(newUser);
        myDirectorySecurity = RemoveExplicitSecurity(myDirectorySecurity);
        dinfo.SetAccessControl(myDirectorySecurity);
        myDirectorySecurity.AddAccessRule(new FileSystemAccessRule(domainAndUsername,
                                         FileSystemRights.FullControl, AccessControlType.Allow));
        dinfo.SetAccessControl(myDirectorySecurity);
        myDirectorySecurity.SetAccessRuleProtection(true, false);
    }
    private static DirectorySecurity RemoveExplicitSecurity(DirectorySecurity directorySecurity)
    {
        AuthorizationRuleCollection rules = directorySecurity.GetAccessRules(true, false, typeof(System.Security.Principal.NTAccount));
        foreach (FileSystemAccessRule rule in rules)
            directorySecurity.RemoveAccessRule(rule);
        return directorySecurity;
    }

在Windows中创建/打开带有读数的目录

假设您正在处理一个简单的场景,您可能正在寻找 Directory.CreateDirectory(字符串路径,DirectorySecurity directorySecurity),您可以在此处找到文档。

那里有一个不错的例子,包括创建基本的访问控制。