几个月前,我在博客上发现了这个 PowerShell 代码。它无需使用外部程序即可将 LAN 唤醒信号发送到您选择的 MAC 地址。我对博文发表了评论,并要求作者描述脚本背后的逻辑,因为我对此感到好奇。我稍后回到博客文章,看看作者是否回复了我的评论。我很惊讶地看到我被重定向到一个页面,作者说他由于崩溃而丢失了他的博客。我不记得它的细节了,但我想我已经没有那个博客了。
所以现在我想请求 Stack Overflow 的聪明人看看这段代码并向我解释它的逻辑。每行的评论都很棒。我很想知道这是如何工作的。它似乎比我发现的其他脚本更强大,因为它可以跨子网工作。不过,我对网络了解不多。
我最好奇的一件事是最后的 for 循环。为什么要多次发送信号?为什么在不同的端口上?但我真的很想知道整个脚本背后的逻辑。
编码:
param (
$targetMac,
$network = [net.ipaddress]::Broadcast,
$subnet = [net.ipaddress]::Broadcast
)
try {
if($network.gettype().equals([string])) {
$network = [net.ipaddress]::Parse($network);
}
if($subnet.gettype().equals([string])) {
$subnet = [net.ipaddress]::Parse($subnet);
}
$broadcast = new-object net.ipaddress (([system.net.ipaddress]::parse("255.255.255.255").address -bxor $subnet.address -bor $network.address))
$mac = [Net.NetworkInformation.PhysicalAddress]::Parse($targetMac.toupper().replace(".",""))
$u = New-Object net.sockets.udpclient
$ep = New-Object net.ipendpoint $broadcast, 0
$ep2 = New-Object net.ipendpoint $broadcast, 7
$ep3 = New-Object net.ipendpoint $broadcast, 9
$payload = [byte[]]@(255,255,255, 255,255,255);
$payload += ($mac.GetAddressBytes()*16)
for($i = 0; $i -lt 10; $i++) {
$u.Send($payload, $payload.Length, $ep) | Out-Null
$u.Send($payload, $payload.Length, $ep2) | Out-Null
$u.Send($payload, $payload.Length, $ep3) | Out-Null
sleep 1;
}
} catch {
$Error | Write-Error;
}