zoukankan      html  css  js  c++  java
  • Setting NTFS Permissions with C#

    Today I needed to set NTFS permissions in C# on some newly created directories.

    No problem I thought, the CLR will have something for it somewhere in Security, so I checked Google in the hopes to find which class to use.

    But Google didn't find anything... This amazed me. "Why can't I control NTFS permissions with .NET ?!?"

    After looking for an hour or so, I found a GotDotNet User Sample, called 'ACLs in .NET'. Finally I thought, now it's going to be plug in and set rights.

    Well this library is great. It makes settings NTFS rights so easy.

    But it lacks a bit in documentation. Therefore I'm providing some of the code I used with it, it could help you. (or it could show my possibly bad coding style, as far as my knowledge goes for know, it should be fine)

    Reference the dll, and use it.

    using Microsoft.Win32.Security;


    Here's a method to add a dir, and set NTFS permissions on it for a given user:

    private Boolean CreateDir(String strSitePath, String strUserName) {

           Boolean bOk;

           try {

                  Directory.CreateDirectory(strSitePath);

                  SecurityDescriptor secDesc = SecurityDescriptor.GetFileSecurity(strSitePath, SECURITY_INFORMATION.DACL_SECURITY_INFORMATION);

                  Dacl dacl = secDesc.Dacl;

                  Sid sidUser = new Sid (strUserName);

     

                  // allow: folder, subfolder and files

                  // modify

                  dacl.AddAce (new AceAccessAllowed (sidUser, AccessType.GENERIC_WRITE | AccessType.GENERIC_READ | AccessType.DELETE | AccessType.GENERIC_EXECUTE , AceFlags.OBJECT_INHERIT_ACE | AceFlags.CONTAINER_INHERIT_ACE));

                 

                  // deny: this folder

                  // write attribs

                  // write extended attribs

                  // delete

                  // change permissions

                  // take ownership

                  DirectoryAccessType DAType = DirectoryAccessType.FILE_WRITE_ATTRIBUTES | DirectoryAccessType.FILE_WRITE_EA | DirectoryAccessType.DELETE | DirectoryAccessType.WRITE_OWNER | DirectoryAccessType.WRITE_DAC;

                  AccessType AType = (AccessType)DAType;

                  dacl.AddAce (new AceAccessDenied (sidUser, AType));

     

                  secDesc.SetDacl(dacl);

                  secDesc.SetFileSecurity(strSitePath, SECURITY_INFORMATION.DACL_SECURITY_INFORMATION);

                  bOk = true;

           } catch {

                  bOk = false;

           }

           return bOk;

    } /* CreateDir */


    The AceFlags determine the level of inheritance on the object.

    And the DirectoryAccessType is used to create a AccessType with some permissions not in the AccessType enum.

    I hope this is useful.

    Estreat  From http://weblogs.asp.net/cumpsd/archive/2004/02/08/69403.aspx

  • 相关阅读:
    cpu核数和逻辑个数的区别_CPU逻辑核心数和物理核心数
    linux查看CPU数
    Java读取excel中日期格式结果为数字44326天
    Java实现读取excel中的数据及图片
    jmeter设置全局变量,获取登录token,实现两个线程组参数公用
    CPU使用率
    快照版本和发布版本区别
    jmeter与postman请求结果返回不一致
    接口认证方式:Bearer Token
    jmeter 中报java.lang.OutOfMemoryError: Java heap space
  • 原文地址:https://www.cnblogs.com/sxlfybb/p/206888.html
Copyright © 2011-2022 走看看