修改文件用户组的访问权限

一朋友问到的,于是参考了范文庆 《精通Windows API--函数接口编程实例》 书中的相关文档,自己整理出一个DEMO,有兴趣看看!

[cpp] view plain copy
 
 print?
  1. /////////////////////////////////////////////////////////////  
  2. // Securtiy.cpp  
  3. // 设置NTFS文件用户组权限  
  4. // BY Koma 2010.04.13  
  5. #include <windows.h>  
  6. #pragma comment(lib,"user32.lib")  
  7. #pragma comment(lib,"Advapi32.lib")  
  8. int WINAPI WinMain(HINSTANCE hInstance, HINSTANCE hPrevInstance, LPSTR pszCmdLine, int cmdShow)  
  9. {  
  10.     SECURITY_ATTRIBUTES sa;                     // 和文件有关的安全结构  
  11.     SECURITY_DESCRIPTOR sd;                     // 声明一个SD  
  12.     BYTE                aclBuffer[1024];        // buffer  
  13.     PACL                pacl = (PACL)&aclBuffer;// 声明一个ACL,长度是1024  
  14.     BYTE                sidBuffer[100];         // sid buffer  
  15.     PSID                psid = (PSID)&sidBuffer;   
  16.       
  17.     // 声明SID,长度是100  
  18.     DWORD        sidBufferSize      = 100;  
  19.     DWORD        domainBufferSize   = 80;  
  20.     char         domainBuffer[80];  
  21.     HANDLE       hFile;  
  22.     SID_NAME_USE snu;  
  23.     // 初始化SD、初始化ACL  
  24.     InitializeSecurityDescriptor(&sd, SECURITY_DESCRIPTOR_REVISION);  
  25.     InitializeAcl(pacl, 1024, ACL_REVISION);  
  26.     // 查找用户Koma,并取该用户的SID  
  27.     LookupAccountName(0, "Koma",psid,&sidBufferSize, domainBuffer,&domainBufferSize, &snu);  
  28.     // 设置该用户的Access-Allowed的ACE,其权限为All-Access  
  29.     AddAccessAllowedAce(pacl, ACL_REVISION, GENERIC_ALL, psid);  
  30.     // 把ACL设置到SD中  
  31.     SetSecurityDescriptorDacl(&sd, TRUE, pacl, FALSE);  
  32.     // 把SD放到文件安全结构SA中  
  33.     sa.nLength              = sizeof(SECURITY_ATTRIBUTES);  
  34.     sa.bInheritHandle       = FALSE;  
  35.     sa.lpSecurityDescriptor = &sd;  
  36.     // 开始创建文件  
  37.     hFile = CreateFile("D://Test.txt",0, 0, &sa, CREATE_NEW, FILE_ATTRIBUTE_NORMAL, 0);  
  38.     if(hFile == INVALID_HANDLE_VALUE)  
  39.     {  
  40.         MessageBox(NULL,"创建失败!",NULL,NULL);  
  41.         return -1;  
  42.     }  
  43.     MessageBox(NULL,"创建成功!",NULL,NULL);  
  44.     CloseHandle(hFile);  
  45.     return 0;  
  46. }  

cl /O2 Securtiy.cpp

http://blog.csdn.net/wangningyu/article/details/5482300

原文地址:https://www.cnblogs.com/findumars/p/5928694.html