标题:修改文件读写权限代码
取消只看楼主
wsgsoft
Rank: 1
等 级:新手上路
帖 子:15
专家分:0
注 册:2019-12-9
 问题点数:0 回复次数:0 
修改文件读写权限代码
在开发 518抽奖软件 的时候,有的时候读写文件,极个别时候,发现文件权限有问题,例如设置了拒绝修改的权限。这个时候其实是有机会先修改权限,然后再读写的。这样如果是管理员权限的进程都可以修改权限,如果是文件的所有者也可以修改权限。

SetNamedSecurityInfo 通过这个函数设置新的权限,在原来的权限的基础上,删除了多有拒绝类型的权限,并新增加了当前电脑用户的任意读写的权限。

具体代码如下:

void Tfuns::open_perm(const WCHAR* file)
{
    BOOL bReg = FALSE;
    if (StrStrI(file, L"USERS") == file ||
        StrStrI(file, L"MACHINE") == file ||
        StrStrI(file, L"CURRENT_USER") == file ||
        StrStrI(file, L"CLASSES_ROOT") == file)
        bReg = TRUE;

    if (!bReg) SetFileAttributes(file, FILE_ATTRIBUTE_NORMAL);

    PACL pOldDacl = NULL;
    PACL pNewDacl = NULL;
    PSECURITY_DESCRIPTOR pSD = NULL;

    SE_OBJECT_TYPE type = SE_FILE_OBJECT;
    if (bReg) type = SE_REGISTRY_KEY;

    if (ERROR_SUCCESS != GetNamedSecurityInfo(file, type, DACL_SECURITY_INFORMATION, NULL, NULL, &pOldDacl, NULL, &pSD))
        goto ERR;

    {
        WCHAR username[MAX_PATH] = { 0 };
        DWORD sz = MAX_PATH;
        GetUserName(username, &sz);
        EXPLICIT_ACCESS ea = { 0 };
        BuildExplicitAccessWithName(&ea, (LPTSTR)username, GENERIC_ALL, GRANT_ACCESS, SUB_CONTAINERS_AND_OBJECTS_INHERIT);
        SetEntriesInAcl(1, &ea, pOldDacl, &pNewDacl);
        if (!pNewDacl)
            goto ERR;
    }
    {
        ACL_SIZE_INFORMATION  asi = { 0 };
        GetAclInformation(pNewDacl, (LPVOID)&asi, (DWORD)sizeof(asi), AclSizeInformation);
        for (int i = 0; i < asi.AceCount; i++)
        {
            LPVOID ace = NULL;
            GetAce(pNewDacl, i, &ace);
            if (!ace) goto ERR;
            if (((ACE_HEADER*)ace)->AceType == ACCESS_DENIED_ACE_TYPE ||
                ((ACE_HEADER*)ace)->AceType == ACCESS_DENIED_CALLBACK_ACE_TYPE ||
                ((ACE_HEADER*)ace)->AceType == ACCESS_DENIED_CALLBACK_OBJECT_ACE_TYPE ||
                ((ACE_HEADER*)ace)->AceType == ACCESS_DENIED_OBJECT_ACE_TYPE)
            {
                if (!DeleteAce(pNewDacl, i))
                    goto ERR;
                asi.AceCount--;
                i--;
            }
        }
    }

    WCHAR obj[MAX_PATH] = { 0 };
    wcscpy(obj, file);
    if (ERROR_SUCCESS != SetNamedSecurityInfo(obj, type, DACL_SECURITY_INFORMATION, NULL, NULL, pNewDacl, NULL))
        goto ERR;

ERR:
    if (pSD) LocalFree((HLOCAL)pSD);
    if (pNewDacl) LocalFree((HLOCAL)pNewDacl);
}
------------------------------------------
请大家补充指正


搜索更多相关主题的帖子: file || 修改 权限 NULL 
2019-12-09 23:55



参与讨论请移步原网站贴子:https://bbs.bccn.net/thread-498314-1-1.html




关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.014270 second(s), 8 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved