首页
学习
活动
专区
工具
TVP
发布
社区首页 >问答首页 >Set-acl在powershell 3.0中不起作用

Set-acl在powershell 3.0中不起作用
EN

Stack Overflow用户
提问于 2013-11-06 14:45:34
回答 1查看 4.9K关注 0票数 3

我有一个新的启动脚本,它在Powershell2.0中工作得很好,但我必须升级到Powershell3.0才能让一些SQL东西工作。然而,这破坏了我的脚本中使用Set-Acl的所有部分。使用Powershell2.0不是一个选择。有没有人找到了解决这个问题的方法:我的代码:

代码语言:javascript
复制
#Set home directory permissions
$inherit = [system.security.accesscontrol.InheritanceFlags]"ContainerInherit, ObjectInherit
$propagation = [system.security.accesscontrol.PropagationFlags]"None"
$acl = Get-Acl $newfolder
$accessrule = New-Object system.security.AccessControl.FileSystemAccessRule("$username", "FullControl", $inherit, $propagation, "Allow")
$acl.AddAccessRule($accessrule)
set-acl -aclobject $acl $newfolder
write-host permissions set

#Set home folder owner
$acl = Get-Acl $newfolder;
$domain = "mydomain" 
$sid = New-Object System.Security.Principal.NTAccount("$domain\$username");
$acl.SetOwner($sid);
Set-Acl $newfolder $acl; 
write-host owner set 
EN

回答 1

Stack Overflow用户

发布于 2013-11-07 03:18:00

尝试使用冒号绑定参数。

示例:

之前:set-acl -aclobject $acl $newfolder

之后:set-acl -aclobject:$acl -Path:$newfolder

注意:使用$newfolder的完整路径。

代码语言:javascript
复制
set-acl -aclobject:$acl -path:$newfolder.FullName

说明: Powershell cmdlet具有有序的绑定和定位,使用冒号可确保将您的值分配给正确的参数,无论对象的顺序或类型如何。.FullName属性将防止SetSecurityDescriptor错误。

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/19805747

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档