次のように、PowerShellを使用してポートが開いているかどうかを確認しようとしました。
(new-object Net.Sockets.TcpClient).Connect("10.45.23.109", 443)
この方法は機能しますが、出力はユーザーフレンドリーではありません。エラーがない場合はアクセスできることを意味します。成功を確認し、「ポート443は動作中です」などのメッセージを表示する方法はありますか?
次のように、PowerShellを使用してポートが開いているかどうかを確認しようとしました。
(new-object Net.Sockets.TcpClient).Connect("10.45.23.109", 443)
この方法は機能しますが、出力はユーザーフレンドリーではありません。エラーがない場合はアクセスできることを意味します。成功を確認し、「ポート443は動作中です」などのメッセージを表示する方法はありますか?
Windows 8 / Windows Server 2012以降を実行している場合は、PowerShellでTest-NetConnectionコマンドを使用できます。
元:
Test-NetConnection -Port 53 -ComputerName LON-DC1
私はいくつかの方法でSalselvaprabuの答えを改善しました:
このように呼んでください:
Test-Port example.com 999
Test-Port 192.168.0.1 80
function Test-Port($hostname, $port)
{
# This works no matter in which form we get $host - hostname or ip address
try {
$ip = [System.Net.Dns]::GetHostAddresses($hostname) |
select-object IPAddressToString -expandproperty IPAddressToString
if($ip.GetType().Name -eq "Object[]")
{
#If we have several ip's for that address, let's take first one
$ip = $ip[0]
}
} catch {
Write-Host "Possibly $hostname is wrong hostname or IP"
return
}
$t = New-Object Net.Sockets.TcpClient
# We use Try\Catch to remove exception info from console if we can't connect
try
{
$t.Connect($ip,$port)
} catch {}
if($t.Connected)
{
$t.Close()
$msg = "Port $port is operational"
}
else
{
$msg = "Port $port on $ip is closed, "
$msg += "You may need to contact your IT team to open it. "
}
Write-Host $msg
}
実際、Shay levyの答えはほぼ正しいですが、彼のコメント欄で述べたように、奇妙な問題が発生しました。したがって、コマンドを2行に分割すると、正常に機能します。
$Ipaddress= Read-Host "Enter the IP address:"
$Port= Read-host "Enter the port number to access:"
$t = New-Object Net.Sockets.TcpClient
$t.Connect($Ipaddress,$Port)
if($t.Connected)
{
"Port $Port is operational"
}
else
{
"Port $Port is closed, You may need to contact your IT team to open it. "
}
Connectedプロパティが$trueに設定されているかどうかを確認し、わかりやすいメッセージを表示できます。
$t = New-Object Net.Sockets.TcpClient "10.45.23.109", 443
if($t.Connected)
{
"Port 443 is operational"
}
else
{
"..."
}
PowerShellの最新バージョンには、新しいコマンドレットTest-NetConnectionがあります。
このコマンドレットを使用すると、実際には、次のようにポートにpingを実行できます。
Test-NetConnection -ComputerName <remote server> -Port nnnn
これは古い質問ですが、(私が行ったように)このページにアクセスしてこの情報を探している場合は、この追加が役立つ可能性があります。
mshutovからの提案を改善しようとしました。出力をオブジェクトとして使用するオプションを追加しました。
function Test-Port($hostname, $port)
{
# This works no matter in which form we get $host - hostname or ip address
try {
$ip = [System.Net.Dns]::GetHostAddresses($hostname) |
select-object IPAddressToString -expandproperty IPAddressToString
if($ip.GetType().Name -eq "Object[]")
{
#If we have several ip's for that address, let's take first one
$ip = $ip[0]
}
} catch {
Write-Host "Possibly $hostname is wrong hostname or IP"
return
}
$t = New-Object Net.Sockets.TcpClient
# We use Try\Catch to remove exception info from console if we can't connect
try
{
$t.Connect($ip,$port)
} catch {}
if($t.Connected)
{
$t.Close()
$object = [pscustomobject] @{
Hostname = $hostname
IP = $IP
TCPPort = $port
GetResponse = $True }
Write-Output $object
}
else
{
$object = [pscustomobject] @{
Computername = $IP
TCPPort = $port
GetResponse = $False }
Write-Output $object
}
Write-Host $msg
}
Test-NetConnectionが利用できない古いバージョンのPowershellを使用している場合は、ホスト名「my.hostname」とポート「123」のワンライナーを次に示します。
$t = New-Object System.Net.Sockets.TcpClient 'my.hostname', 123; if($t.Connected) {"OK"}
OKまたはエラーメッセージを返します。
mshutov&Salselvaprabuによる素晴らしい答え。もう少し堅牢なものが必要でした。最初のIPアドレスだけをチェックするのではなく、提供されたすべてのIPアドレスをチェックしました。
また、Test-Connection関数よりもいくつかのパラメーター名と機能を複製したかったのです。
この新しい関数を使用すると、再試行回数のカウントと、各試行間の遅延を設定できます。楽しみ!
function Test-Port {
[CmdletBinding()]
Param (
[string] $ComputerName,
[int] $Port,
[int] $Delay = 1,
[int] $Count = 3
)
function Test-TcpClient ($IPAddress, $Port) {
$TcpClient = New-Object Net.Sockets.TcpClient
Try { $TcpClient.Connect($IPAddress, $Port) } Catch {}
If ($TcpClient.Connected) { $TcpClient.Close(); Return $True }
Return $False
}
function Invoke-Test ($ComputerName, $Port) {
Try { [array]$IPAddress = [System.Net.Dns]::GetHostAddresses($ComputerName) | Select-Object -Expand IPAddressToString }
Catch { Return $False }
[array]$Results = $IPAddress | % { Test-TcpClient -IPAddress $_ -Port $Port }
If ($Results -contains $True) { Return $True } Else { Return $False }
}
for ($i = 1; ((Invoke-Test -ComputerName $ComputerName -Port $Port) -ne $True); $i++)
{
if ($i -ge $Count) {
Write-Warning "Timed out while waiting for port $Port to be open on $ComputerName!"
Return $false
}
Write-Warning "Port $Port not open, retrying..."
Sleep $Delay
}
Return $true
}
これを1つのライナーにまとめると、変数「$ port389Open」がTrueまたはfalseに設定されます。これは、ポートのリストに対してすばやく簡単に複製できます。
try{$socket = New-Object Net.Sockets.TcpClient($ipAddress,389);if($socket -eq $null){$Port389Open = $false}else{Port389Open = $true;$socket.close()}}catch{Port389Open = $false}
本当に夢中になりたい場合は、配列全体を返すことができます-
Function StdPorts($ip){
$rst = "" | select IP,Port547Open,Port135Open,Port3389Open,Port389Open,Port53Open
$rst.IP = $Ip
try{$socket = New-Object Net.Sockets.TcpClient($ip,389);if($socket -eq $null){$rst.Port389Open = $false}else{$rst.Port389Open = $true;$socket.close();$ipscore++}}catch{$rst.Port389Open = $false}
try{$socket = New-Object Net.Sockets.TcpClient($ip,53);if($socket -eq $null){$rst.Port53Open = $false}else{$rst.Port53Open = $true;$socket.close();$ipscore++}}catch{$rst.Port53Open = $false}
try{$socket = New-Object Net.Sockets.TcpClient($ip,3389);if($socket -eq $null){$rst.Port3389Open = $false}else{$rst.Port3389Open = $true;$socket.close();$ipscore++}}catch{$rst.Port3389Open = $false}
try{$socket = New-Object Net.Sockets.TcpClient($ip,547);if($socket -eq $null){$rst.Port547Open = $false}else{$rst.Port547Open = $true;$socket.close();$ipscore++}}catch{$rst.Port547Open = $false}
try{$socket = New-Object Net.Sockets.TcpClient($ip,135);if($socket -eq $null){$rst.Port135Open = $false}else{$rst.Port135Open = $true;$socket.close();$SkipWMI = $False;$ipscore++}}catch{$rst.Port135Open = $false}
Return $rst
}
閉じたポートをスキャンすると、長時間応答しなくなります。fqdnを次のようにipに解決する方が速いようです。
[System.Net.Dns]::GetHostAddresses("www.msn.com").IPAddressToString