如何解决ForEach-Object - 尝试循环变量中的每个地址
毫无疑问,又问了一个愚蠢的问题。我正在尝试为我创建的变量中存在的每个 IP 地址执行 for 循环。我可以创建以逗号或空格分隔的字符串,但无论哪种方式,我都无法让 for 循环执行我想要的操作。
我希望列表中的每个地址都传递到这个代码块中
az network application-gateway waf-policy custom-rule match-condition add `
--match-variables RemoteAddr `
--operator IPMatch `
--values <ADDRESS_FROM_STRING>
我正在根据这段脚本构建列表
$addressList = Invoke-WebRequest "https://rules.emergingthreats.net/blockrules/compromised-ips.txt" -UseBasicParsing | Select-Object -ExpandProperty Content
$threatList=(-split $addressList -join ',')
这是我在这方面的微弱尝试,我认为这是错误的,但我对 foreach 和 foreach-object 的理解可能超出了我的深度。
$threatlist | ForEach-Object -process (az network application-gateway waf-policy custom-rule match-condition add `
--match-variables RemoteAddr `
--operator IPMatch `
--values $_)
任何帮助将不胜感激,谢谢大家!
解决方法
充实 Mathias R. Jessen 和 guiwhatsthat 给出的指针:
-
使用
Invoke-RestMethod
(其内置别名为irm
),它直接返回感兴趣的文本(它是带有IP地址的单个字符串,每个字符串都在自己的行上)。 -
使用
-split
的一元形式,即 string splitting operator,将多行字符串拆分为一个 array 标记(通过任何空格,在本例中,这意味着每个 IP 地址都成为其自己的数组元素。 -
使用带有数组的
ForEach-Object
cmdlet 作为输入,它会处理您传递给它的 script block ({ ... }
) 中的每个元素,其中 {{3} } 指的是手头的输入对象(在本例中为字符串)。
-split (irm "https://rules.emergingthreats.net/blockrules/compromised-ips.txt") |
ForEach-Object {
az network application-gateway waf-policy custom-rule match-condition add `
--match-variables RemoteAddr `
--operator IPMatch `
--values $_
}
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。