在 Windows 中更改文件所有者

发布于 2024-08-21 10:11:05 字数 122 浏览 1 评论 0原文

Windows 中是否有类似于 Linux 的 chown 的 API?

Is there an API in Windows similar to Linux's chown?

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(2

自控 2024-08-28 10:11:05

取自此处: http://www.perlmonks.org/?node_id=70562

    // #includes omitted for the sake of sanity
    HANDLE token;
    char *filename = "somefile.txt";
    char *newuser = "someuser";
    DWORD len;
    PSECURITY_DESCRIPTOR security = NULL;
    PSID sidPtr = NULL;
    int retValue = 1;

    // Get the privileges you need
    if (OpenProcessToken(GetCurrentProcess(), TOKEN_ADJUST_PRIVILEGES, &token)) {
        SetPrivilege(token, "SeTakeOwnershipPrivilege", 1);
        SetPrivilege(token, "SeSecurityPrivilege", 1);
        SetPrivilege(token, "SeBackupPrivilege", 1);
        SetPrivilege(token, "SeRestorePrivilege", 1);
    } else retValue = 0;

    // Create the security descriptor
    if (retValue) {
        GetFileSecurity(filename, OWNER_SECURITY_INFORMATION, security, 0, &len);
        security = (PSECURITY_DESCRIPTOR)malloc(len);
        if (!InitializeSecurityDescriptor(security, SECURITY_DESCRIPTOR_REVISION))
            retValue = 0;
    }

    // Get the sid for the username
    if (retValue) {
        char domainbuf[4096];
        DWORD sidSize = 0;
        DWORD bufSize = 4096;
        SID_NAME_USE sidUse;
        LookupAccountName(NULL, newuser, sidPtr, &sidSize, domainbuf, &bufSize, &sidUse);
        sid = (PSID)malloc(sidSize);
        if (!LookupAccountName(NULL, string, (PSID)sid, &sidSize, domainbuf, &bufSize, &sidUse))
            retValue = 0;
        }
    }

    // Set the sid to be the new owner
    if (retValue && !SetSecurityDescriptorOwner(security, sidPtr, 0))
        retValue = 0;

    // Save the security descriptor
    if (retValue)
        retValue = SetFileSecurity(filename, OWNER_SECURITY_INFORMATION, security);
    if (security) free(security);
    if (sid) free(sid);
    return retValue;

`

Taken from here: http://www.perlmonks.org/?node_id=70562

    // #includes omitted for the sake of sanity
    HANDLE token;
    char *filename = "somefile.txt";
    char *newuser = "someuser";
    DWORD len;
    PSECURITY_DESCRIPTOR security = NULL;
    PSID sidPtr = NULL;
    int retValue = 1;

    // Get the privileges you need
    if (OpenProcessToken(GetCurrentProcess(), TOKEN_ADJUST_PRIVILEGES, &token)) {
        SetPrivilege(token, "SeTakeOwnershipPrivilege", 1);
        SetPrivilege(token, "SeSecurityPrivilege", 1);
        SetPrivilege(token, "SeBackupPrivilege", 1);
        SetPrivilege(token, "SeRestorePrivilege", 1);
    } else retValue = 0;

    // Create the security descriptor
    if (retValue) {
        GetFileSecurity(filename, OWNER_SECURITY_INFORMATION, security, 0, &len);
        security = (PSECURITY_DESCRIPTOR)malloc(len);
        if (!InitializeSecurityDescriptor(security, SECURITY_DESCRIPTOR_REVISION))
            retValue = 0;
    }

    // Get the sid for the username
    if (retValue) {
        char domainbuf[4096];
        DWORD sidSize = 0;
        DWORD bufSize = 4096;
        SID_NAME_USE sidUse;
        LookupAccountName(NULL, newuser, sidPtr, &sidSize, domainbuf, &bufSize, &sidUse);
        sid = (PSID)malloc(sidSize);
        if (!LookupAccountName(NULL, string, (PSID)sid, &sidSize, domainbuf, &bufSize, &sidUse))
            retValue = 0;
        }
    }

    // Set the sid to be the new owner
    if (retValue && !SetSecurityDescriptorOwner(security, sidPtr, 0))
        retValue = 0;

    // Save the security descriptor
    if (retValue)
        retValue = SetFileSecurity(filename, OWNER_SECURITY_INFORMATION, security);
    if (security) free(security);
    if (sid) free(sid);
    return retValue;

`

是你 2024-08-28 10:11:05

您可能会发现 cacls 或 icacls 命令 很有用...它们使用起来并不简单不过

你能提供更多关于你想要做什么的信息吗?

You might find the cacls or icacls commands useful... They're not exactly straightforward to use though

Can you provide a bit more information on what you're trying to do?

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文