青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

Modifying Existing DACLs of an Object Program Example

// Modifying DACL of an object. In ACL there are ACEs...

// Here we are going to add deny standard right

// access for Administrators group. This Win XP machine is

// logged in by user named Mike spoon who is a member of Administrators group

#include <windows.h>

#include <aclapi.h>

#include <stdio.h>

 

// Clean up the allocated resources

void Cleanup(PSECURITY_DESCRIPTOR pSD, PACL pNewDACL)

{

      if(pSD != NULL)

            LocalFree((HLOCAL) pSD);

      else

            wprintf(L"pSD freed up\n");

      if(pNewDACL != NULL)

            LocalFree((HLOCAL) pNewDACL);

      else

            wprintf(L"pNewDACL freed up\n");

}

 

int wmain(int argc, WCHAR **argv)

{

      // Name of object, here we will add ACE for a directory

      // the directory is already created

      LPTSTR pszObjName = L"\\\\?\\C:\\NewDACLDir";

      // Type of object, file or directory.  Here we test on directory

      SE_OBJECT_TYPE ObjectType = SE_FILE_OBJECT;

      // Access mask for new ACE equal to 0x001F0000 flags (bit 0 till 15)

      DWORD dwAccessRights = STANDARD_RIGHTS_ALL;

      // Type of ACE, Access denied ACE

      ACCESS_MODE AccessMode = DENY_ACCESS;

      // Inheritance flags for new the ACE. The OBJECT_INHERIT_ACE and

      // CONTAINER_INHERIT_ACE flags are

      // not propagated to an inherited ACE.

      DWORD dwInheritance = NO_PROPAGATE_INHERIT_ACE;

      // format of trustee structure, the trustee is name

      TRUSTEE_FORM TrusteeForm = TRUSTEE_IS_NAME;

     

      // Trustee for new ACE.  This just for fun...When you run once, only one

      // element will take effect.  By changing the first array element we

      // can change to other trustee and re run the program....

      // Other than Mike spoon, they are all well known trustees

      // Take note the localization issues

      WCHAR pszTrustee[4][15] = {L"Administrators", L"System", L"Users", L"Mike spoon"};

     

      // Result

      DWORD dwRes = 0;

      // Existing and new DACL pointers...

      PACL pOldDACL = NULL, pNewDACL = NULL;

      // Security descriptor

      PSECURITY_DESCRIPTOR pSD = NULL;

      SecureZeroMemory(&pSD, sizeof(PSECURITY_DESCRIPTOR));

      // EXPLICIT_ACCESS structure.  For more than one entries,

      // declare an array of the EXPLICIT_ACCESS structure

      EXPLICIT_ACCESS ea;

 

      // Verify the object name validity

      if(pszObjName == NULL)

      {

            wprintf(L"The object name is invalid!\n");

            return ERROR_INVALID_PARAMETER;

      }

      else

            wprintf(L"The object name is valid, \"%s\"\n", pszObjName);

     

      // Verify that our new trustee strings is OK

      for(int i = 0; i <= 3; i++)

            wprintf(L"Test pointer #%d: %s\n", i, pszTrustee[i]);

     

      // Get a pointer to the existing DACL.

      dwRes = GetNamedSecurityInfo(pszObjName, ObjectType,

            DACL_SECURITY_INFORMATION,

            NULL,

            NULL,

            &pOldDACL,

            NULL,

            &pSD);

     

      // Verify

      if(dwRes != ERROR_SUCCESS)

      {

            wprintf(L"GetNamedSecurityInfo() failed, error %u\n", dwRes);

            Cleanup(pSD, pNewDACL);

      }

      else

            wprintf(L"GetNamedSecurityInfo() is OK\n");

     

      // Initialize an EXPLICIT_ACCESS structure for the new ACE.

      // For more entries, declare an array of the EXPLICIT_ACCESS structure

      SecureZeroMemory(&ea, sizeof(EXPLICIT_ACCESS));

      ea.grfAccessPermissions = dwAccessRights;

      ea.grfAccessMode = AccessMode;

      ea.grfInheritance= dwInheritance;

      ea.Trustee.TrusteeForm = TrusteeForm;

     

      // Test for Administrators group, a new trustee for the ACE

      // For other trustees, you can try changing

      // the array index to 1, 2 and 3 and rerun, see the effect

      ea.Trustee.ptstrName = (LPTSTR)(pszTrustee[0]);

     

      // Create a new ACL that merges the new ACE into the existing DACL.

      dwRes = SetEntriesInAcl(1, &ea, pOldDACL, &pNewDACL);

     

      //  Verify

      if(dwRes != ERROR_SUCCESS)

      {

            wprintf(L"SetEntriesInAcl() failed, error %u\n", dwRes);

            Cleanup(pSD, pNewDACL);

      }

      else

            wprintf(L"SetEntriesInAcl() working fine!\n");

     

      // Attach the new ACL as the object's DACL.

      dwRes = SetNamedSecurityInfo(pszObjName, ObjectType,

            DACL_SECURITY_INFORMATION,

            NULL,

            NULL,

            pNewDACL,

            NULL);

     

      if(dwRes != ERROR_SUCCESS)

      {

            wprintf(L"SetNamedSecurityInfo() failed, error %u\n", dwRes);

            Cleanup(pSD, pNewDACL);

      }

      wprintf(L"SetNamedSecurityInfo() is OK\n");

      return 0;

}

Build and run the project. The following screenshot is a sample output.

 

 

Then verify through the C:\NewDACLDir directory property pages again.

 

 

Under the Permission for Administrators group, the Special Permissions is ticked for the Deny permission.  Keep in mind that Deny overrides the Allow permission.  The following figure also confirmed that our new ACE for the Deny is not inherited.

 

 

Remember that, DENY overwrites ALLOW permission.  For this case because Mike spoon is a member of the Administrators group, however he cannot delete or open the C:\\NewDACLDir directory.  We have to log off and login again as other Administrators group user or create another user that is a member of Administrators or take the object’s ownership or just edit the permission entries (shown at the end of this section).  When we try to delete the folder, the following message was displayed. Well, it funny isn’t it? A user of Administrators group cannot delete/open his/her own folder.

 

 

It is same when we want to open the folder, it is not accessible.

 

 

So, whatever it is, please don’t mess up your machine. The following steps show how to re-enable the Full Control for Administrators group.

 

 

 

posted on 2011-08-23 13:41 wrh 閱讀(473) 評論(1)  編輯 收藏 引用

評論

# re: Modifying Existing DACLs of an Object Program Example 2011-08-23 13:51 代孕

我來逛逛,順便幫博主頂一下,嘿嘿。  回復  更多評論   

導航

<2011年8月>
31123456
78910111213
14151617181920
21222324252627
28293031123
45678910

統計

常用鏈接

留言簿(19)

隨筆檔案

文章檔案

收藏夾

搜索

最新評論

閱讀排行榜

評論排行榜

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            亚洲高清免费| 久久久久se| 免费欧美视频| 狂野欧美激情性xxxx| 亚洲第一精品久久忘忧草社区| 欧美成人综合网站| 欧美96在线丨欧| 一本色道**综合亚洲精品蜜桃冫| 日韩特黄影片| 国产精品一区久久久| 久久综合国产精品台湾中文娱乐网| 久久久一区二区三区| 9i看片成人免费高清| 亚洲特级片在线| 国产日韩免费| 亚洲成色777777女色窝| 欧美日韩另类一区| 久久久久成人精品| 欧美成人免费一级人片100| 亚洲特色特黄| 欧美在线视频免费观看| 亚洲美女色禁图| 亚洲欧美在线免费| 最新国产成人在线观看| 亚洲桃花岛网站| 亚洲国产精品123| 一区二区三区不卡视频在线观看| 激情久久久久久| 中文欧美在线视频| 亚洲国产美女| 亚洲一区二区三区精品在线观看| 亚洲国产精品一区二区尤物区| 一区二区三区黄色| 91久久精品www人人做人人爽| 中日韩男男gay无套| 亚洲国产精品成人va在线观看| 亚洲一区日本| 99精品久久| 老司机精品福利视频| 小黄鸭精品aⅴ导航网站入口| 欧美大片18| 久久免费的精品国产v∧| 欧美日韩一区自拍| 亚洲电影在线看| 国色天香一区二区| 亚洲欧美电影在线观看| aⅴ色国产欧美| 久久夜色精品国产| 久久久久国产一区二区三区| 国产精品www色诱视频| 亚洲国产黄色| 亚洲国产美女| 久久嫩草精品久久久精品| 久久精品国产久精国产思思| 亚洲视频国产视频| 欧美伦理一区二区| 亚洲高清在线播放| 亚洲精品日韩激情在线电影| 久久久久久国产精品一区| 久久av免费一区| 国产日韩欧美夫妻视频在线观看| 亚洲一区二区三区乱码aⅴ| 中日韩美女免费视频网址在线观看 | 欧美成人一二三| 毛片一区二区三区| 黑丝一区二区三区| 久久成人羞羞网站| 久久综合久色欧美综合狠狠| 国产在线播精品第三| 香蕉久久久久久久av网站| 欧美伊人久久大香线蕉综合69| 国产精品日韩久久久久| 亚洲欧美日本精品| 久久久久免费| 在线播放豆国产99亚洲| 麻豆乱码国产一区二区三区| 久久综合九色综合久99| 亚洲国产mv| 欧美激情亚洲一区| 日韩一级黄色av| 午夜精品久久久久久久99黑人| 国产九色精品成人porny| 欧美伊人影院| 欧美成人一区二区三区片免费| 亚洲日韩成人| 欧美视频中文一区二区三区在线观看 | 亚洲激情国产| 亚洲视频在线一区| 国产精品一区二区黑丝| 久久国产精品一区二区三区| 欧美成年人视频网站欧美| 亚洲六月丁香色婷婷综合久久| 欧美日韩一区二区三区在线视频| 亚洲影视在线播放| 美女主播一区| 亚洲午夜三级在线| 国内成+人亚洲| 欧美美女喷水视频| 欧美亚洲综合在线| 亚洲国产精品女人久久久| 亚洲欧美日韩天堂| 亚洲成色999久久网站| 欧美日韩中字| 久久婷婷人人澡人人喊人人爽 | 欧美在线视频一区| 亚洲精品在线观看免费| 国产精品一区二区三区成人| 久久精品伊人| 亚洲午夜在线观看视频在线| 嫩草伊人久久精品少妇av杨幂| 亚洲视频在线播放| 亚洲激情图片小说视频| 国产精品一卡| 欧美喷潮久久久xxxxx| 久久精品免费看| 亚洲一级网站| 亚洲毛片在线| 欧美护士18xxxxhd| 久久久免费精品视频| 欧美成人性网| 久久精品30| 亚洲午夜性刺激影院| 亚洲精品国产欧美| 欧美xx视频| 久久资源在线| 久久精品国产v日韩v亚洲 | 国产欧美日韩一区二区三区| 欧美日韩成人一区二区三区| 久久久久久久999| 欧美一区二区黄| 亚洲无限av看| 一区二区三区国产精华| 亚洲精品免费在线播放| 欧美国内亚洲| 欧美高清在线一区二区| 免费欧美电影| 欧美成人精品福利| 美女精品网站| 免费永久网站黄欧美| 久久精品首页| 久久久噜久噜久久综合| 久久久精彩视频| 久久久久免费| 蜜臀久久久99精品久久久久久| 久久久最新网址| 老司机一区二区| 欧美大片免费看| 亚洲国产一区二区三区青草影视| 亚洲国产成人久久综合一区| 亚洲第一视频| 99re6这里只有精品| 99国产欧美久久久精品| 亚洲调教视频在线观看| 亚洲一区亚洲二区| 性视频1819p久久| 久久久久.com| 欧美精品成人一区二区在线观看 | 久久久www成人免费无遮挡大片| 久久蜜桃资源一区二区老牛| 欧美成人亚洲| 国产精品久久国产愉拍| 国产一区二区高清不卡| 亚洲第一区在线| 一本一本a久久| 欧美一区二区免费| 免费在线视频一区| 91久久在线观看| 亚洲一区免费看| 久久频这里精品99香蕉| 欧美日本乱大交xxxxx| 国产精品成人久久久久| 国产一区二区三区久久| 亚洲福利在线观看| 亚洲一区视频在线观看视频| 久久精品国产99精品国产亚洲性色| 欧美电影免费观看大全| 国产精品99久久99久久久二8 | 亚洲综合视频一区| 久久久久久尹人网香蕉| 欧美日本不卡高清| 国产一区观看| 日韩一二三区视频| 久久精品99| 99国产精品自拍| 久久女同互慰一区二区三区| 国产精品成人一区二区艾草| 一区二区三区在线观看国产| 国产精品99久久久久久www| 久久这里只有| 亚洲天堂av在线免费观看| 久久精品九九| 国产精品伦一区| 最新国产成人在线观看| 久久精品国产第一区二区三区最新章节 | 狠狠88综合久久久久综合网| 中文有码久久| 欧美激情2020午夜免费观看| 午夜精品久久久久久久白皮肤| 欧美专区福利在线| 91久久午夜|