加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 编程开发 > Python > 正文

使用Python重置NTFS文件夹的继承权限

发布时间:2020-12-20 13:29:34 所属栏目:Python 来源:网络整理
导读:我在NTFS分区(在 Windows 2008上)上有很多文件夹,这些文件夹不会从父项继承权限. 我想重置它,以便它们包括那些父权限(相当于检查“高级安全设置”区域下的“包括此对象的父级的可继承权限”复选框). 由于我们在这里使用Python进行其他一些系统管理任务,如果
我在NTFS分区(在 Windows 2008上)上有很多文件夹,这些文件夹不会从父项继承权限.

我想重置它,以便它们包括那些父权限(相当于检查“高级安全设置”区域下的“包括此对象的父级的可继承权限”复选框).

由于我们在这里使用Python进行其他一些系统管理任务,如果可能的话我想用Python做(我知道如何在VBScript中做到这一点,但这不是一次性的脚本,而是定期运行,所以应该与我们的代码库的其余部分集成).

我一直在使用优秀的pywin32扩展和http://timgolden.me.uk/python/win32_how_do_i.html和Google的示例开始,但我没有看到任何方式简单地说“从父级继承权限”.

使用AddAccessAllowedAceEx,我甚至可以通过添加INHERITED_ACE标志来伪造某些东西的继承,无论它是否真的来自父级:

dacl.AddAccessAllowedAceEx( 
  win32security.ACL_REVISION_DS ,win32security.OBJECT_INHERIT_ACE | win32security.CONTAINER_INHERIT_ACE | win32security.INHERITED_ACE ,ntsecuritycon.FILE_GENERIC_READ | ntsecuritycon.FILE_GENERIC_EXECUTE ,some_sid_here 
)

但是,除非我从根文件夹走完整个路径并一直构建继承,否则我怎么知道要继承哪些东西呢?

解决方法

需要在根文件夹的ACE上设置OBJECT_INHERIT_ACE和CONTAINER_INHERIT_ACE.您可能还希望清除直接在每个子文件夹和文件上设置的任何权限. (那些将在ACE标志中不包含INHERITED_ACE的那些).

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读