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


    一朋友问到的,于是参考了范文庆 《精通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

  • 相关阅读:
    Tomcat 7.x 6.x 和 JDK 7 旧版本下载教程
    下载ios系统文件,使用UltraISO刻录系统(windows Server)光盘,安装操作系统
    MSDN, 我告诉你
    669. 修剪二叉搜索树
    99. 恢复二叉搜索树
    windows系统 python安装uwsgi教程
    mysql5.7修改密码命令
    客户端浏览器访问django服务器
    二、kafka的环境部署+命令行
    二十、SpringCloud Alibaba Seata处理分布式事务(一、基础)
  • 原文地址:https://www.cnblogs.com/findumars/p/5928694.html
Copyright © 2020-2023  润新知