- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在尝试在 C++ 中以编程方式将文件的所有者设置为另一个用户。
我确实为我的进程启用了 SeRestorePrivilege
。我可以使用 Process Explorer 确认这一点。我开始这个过程,它被禁用,我运行我的代码来启用它,ProcExp 报告它已启用,我刚好到达要设置所有者的位置,它仍然启用(即我不是意外禁用它)。
这个access is denied消息还有什么其他原因导致的?我没有考虑到什么?
std::wstring fileSystemObject = L"C:\test.txt";
*status_code = SetNamedSecurityInfo((wchar_t*)fileSystemObject.c_str(), SE_FILE_OBJECT, OWNER_SECURITY_INFORMATION, pSID, NULL, NULL, NULL);
if (*status_code == ERROR_SUCCESS)
{
Log(L"Successfully set owner for " + fileSystemObject);
return true;
}
else
{
Log(L"Failed to set owner for " + fileSystemObject + L". Error code: ", *status_code);
return false;
}
谢谢。
编辑:非常感谢您一直以来的帮助。非常感谢。
我将您的代码用于以下所有测试。基本上,我也从您的代码中收到拒绝访问消息,但是,我已经对其进行了更多追踪。
首先,“C:\test.txt”不是我的真实代码,不幸的是,丢失的反斜杠不是导致我出现问题的原因。谢谢你敏锐的眼光:)
此外,我正在运行禁用 UAC 的管理员帐户,并且我的程序在 list 中设置了 requireAdministrator。
但是,我注意到我的代码和您的代码都适用于简单文件。经过多次测试,我发现我只会在以下情况下收到 AccessDenied 消息:
1:我不是所有者,“取得所有权”权限设置为拒绝,例如每个人。
2:我是所有者,“取得所有权”权限设置为拒绝,例如每个人。奇怪的是,在第二个实例中,尽管有失败代码,但所有权确实发生了变化。
我不明白为什么会这样。我和你已经在进程 token 中设置了 SE_RESTORE_NAME。我应该被允许任意设置所有者 SID。但是我好像做不到。
似乎对 TakeOwnership DACL 的任何拒绝都会覆盖我取得所有权的能力。但是,在获得所有权之前我无法更改权限! 叹气。
我可能会尝试按照您最初的建议设置 SeTakeOwnershipPrivilege,将所有权归我所有,更改权限,在外部设置所有权。多么痛苦啊。而且我什至不太相信它会奏效。
我还发现了这个:http://us.generation-nt.com/setnamedsecurityinfo-failing-rc-1307-help-59729462.html
他似乎处于类似情况(如果我没有正确设置进程 token ,我会得到 1307)。但是 CreatePrivateObjectSecurityEx 需要进行更多设置。
嗯嗯。感谢您的宝贵时间。
最佳答案
这里的问题是安全子系统和模型正在保护对象免受不合理的所有权更改,即使拥有管理员权限也需要正确克服障碍。
获取文件的所有权涉及两个权限:SE_TAKE_OWNERSHIP_NAME
和 SE_RESTORE_NAME
。前者允许拿走某人的对象,后者允许设置不是设置者本人的所有者。
看起来 SE_RESTORE_NAME
是一个更强大的权限并且足以完成任务,但事实并非如此。是的,它允许设置某人的所有权,as MSDN states :
If the caller does not have the SeRestorePrivilege constant (see Privilege Constants), this SID must be contained in the caller's token, and must have the SE_GROUP_OWNER permission enabled. The SecurityInfo parameter must include the OWNER_SECURITY_INFORMATION flag. To set the owner, the caller must have WRITE_OWNER access to the object or have the SE_TAKE_OWNERSHIP_NAME privilege enabled.
但是,它不会让您克服明确阻止所有权更改的 DACL 项目。在这种情况下,您还需要其他特权(也就是说,您需要同时启用这两种特权),这使您能够在决定将所有权授予谁之前从某人那里获得所有权。
我正在从上面的评论中复制指向 C++/ATL 源代码的链接:SetFileOwner.cpp .当 permissions/DACL 有 Deny 项时,会发生异常,启用第二权限即可解决问题。
关于c++ - ERROR_ACCESS_DENIED 设置文件所有者,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/12338711/
假设我有一个简单的模型: class Contact(models.Model): owner = models.ForeignKey(User, editable=False) fi
我在docker容器中的轨道上运行ruby。如果生成类似docker-compose run rails rails g controller posts index show的文件,则文件所有者为r
这个问题在这里已经有了答案: Get Component's Parent Form (10 个答案) 关闭 3 年前。 如何从嵌入到表单中的自定义 Winforms 组件获取父/所有者控件? 我有
我这里有密码 @interface FFRightSidebarController () @property (nonatomic, strong) FFActivitiesController *
假设您有这些表:RestaurantChains、Restaurants、MenuItems - 它们之间存在明显的关系。现在,您有表 Comments 和 Ratings,它们存储客户对链式店、餐馆
我有以下 View 层次结构, ... ... .... 单个订单的更新通过推送器进行。 我是 React 新手,想知道以下哪一个是更
所以我有一个位于另一个用户控件内部的用户控件。我们称它们为 ParentUC 和 ChildUC。我需要从 ChildUC 获取 ParentUC。 我知道获取窗口所有者的方法是Window.GetW
我们创建了 Telegram Bot ,它有许多困难的操作。机器人是由一位开发人员使用他的电话号码创建的。是否可以更改机器人的所有者或添加其他用户作为机器人的管理员? 最佳答案 最近出现了将机器人转给
默认情况下,对象(表、存储过程等)是使用 dbo 所有者/架构设置的(我认为 ms sql 2000 称其为所有者,而 ms sql 2005 称其为架构) 所有者/架构实际上是数据库中的角色或用户。
在 Mortar 中,如果 ActionBar 根据显示的屏幕发生变化,我很好奇人们如何处理它。例如,假设您想要在显示特定屏幕时更改 ActionBar 标题或操作。 注入(inject) Activ
我正在使用 Stripe.js 和 Stripe Elements 开发购物车结帐页面,而不是使用 Stripe 的结帐小部件。 在结帐页面上,使用了所有 4 个可用元素(卡片、邮政编码、expire
我尝试将本地仓库推送到 github 并收到这样的消息: The remote end hung up unexpectedly. ERROR: Permission to [repo_name] d
我是 WHM、cPanel 和 CentOS 的新手。 我安装 WHM 然后为域创建一个帐户 app.example.com和用户 peter我将域名指向正确的 IP 地址,但是当我运行我的网站 ap
我已经在 GitHub 上提交了一个项目的问题,该项目不是我的,我也不是贡献者,但我找不到标记我的问题的方法。有没有办法让我给它贴上标签,或者这只适用于贡献者? 最佳答案 它仅适用于贡献者。 这样,您
我到处都找过了,但一直找不到我要找的东西。我知道我需要什么,但无法将 2 和 2 放在一起。 我需要允许用户创建群组并允许其他用户加入群组。 任何用户都可以创建群组。 任何用户都可以发送加入另一个群组
我到处都找过了,但一直找不到我要找的东西。我知道我需要什么,但无法将 2 和 2 放在一起。 我需要允许用户创建群组并允许其他用户加入群组。 任何用户都可以创建群组。 任何用户都可以发送加入另一个群组
这是我的代码: class SpecialMeanings{ String prop1 = "prop1" def closure = { String prop1 = "inner_
我一直在使用 java OWNER 进行基于属性的配置。 我创建了一个静态方法 public static final ApplicationConfiguration config = Config
我正在运行 OpenSSH sftp-server(Linux、Raspbian),FileZilla 用作客户端。我遇到的问题是用户可以删除服务器上的任何文件,而不管文件掩码或所有者/组: 登录的用
这是一个简单的问题,我无法通过谷歌搜索和查看 github documents 找到答案。 . 如果有人对 github 中已关闭的问题发表新评论,是否会通知 Repo 所有者? 最佳答案 如果向已关
我是一名优秀的程序员,十分优秀!