监听端口是计算机当前正在使用的端口,用于建立计算机之间的网络连接。虽然打开、监听和关闭网络端口的过程是无缝的,但识别当前打开或监听的端口可以帮助解决与网络相关的问题。
在 Windows 中,有两个主要命令可用于检查打开的监听端口:
- Netstat(命令提示符)
- Get-NetTCPConnection(PowerShell)
这两个命令对于 IT Pro 和系统管理员非常有用,本文将介绍如何使用「命令提示符」和 PowerShell 查看 Windows 打开和监听的端口。
监听端口的类型
打开或监听的端口是 Windows 中应用程序或服务正在使用的端口,用于与其它网络设备建立连接。在 Windows 中有两种类型的连接端口:
- TCP(传输控制协议)
- UDP(用户数据报协议)
Windows 中的不同应用程序会打开不同的端口(TCP 或 UDP),UDP 速度更快但不太安全,而 TCP 速度较慢但更安全。
使用 Netstat 命令查看 Windows 监听端口
要查看 Windows 占用的监听端口,请按以下步骤操作:
1在「开始」菜单中搜索 cmd
– 选择「以管理员身份运行」以打开「命令提示符」。
2按以下方式运行 Netstat 命令:
netstat -a
#或
netstat -ano
-a
开关显示 Windows 正在监听的所有活动连接,包括 TCP 和 UDP。-o
开关显示每个进程的 PID。-n
开关以数值形式显示 IP 地址和端口号。
使用 Netstat 在命令提示符中检查侦听端口
上述命令会输出以下内容:
- 协议(TCP 或 UDP)
- 本地地址(当前 Windows 设备的 IP 地址)
- 外部地址(远程设备的 IP 地址)
- 状态(Listening、Established、Time_Wait 和 Close_Wait)
- PID(打开该端口的进程 PID)
3「本地地址」中的「:」冒号后面跟的数字是监听端口号。如果只查看监听状态的端口,可以运行以下命令:
netstat -aon | findstr /i listening
使用 Netstat 在命令提示符中列出所有侦听端口
「外部地址」字段中的 0.0.0.0:0
表示该端口用于广播。
您可以配合以下参数与 Netstat 命令一起使用:
参数 | 描述 |
---|---|
-a | 显示包括 TCP 和 UDP 在内的所有连接。 |
-n | 以数值形式显示 IP 地址和端口号。 |
-o | 显示进程 PID。 |
-p | 显示特定协议的连接。 |
-r | 显示内核路由表。 |
-s | 按协议显示统计信息。 |
-t | 显示当前活动的连接。 |
-f | 将 IP 地址解析为 FQDN。 |
-e | 显示网络统计信息,包括错误、字节数、发送和接收的数据包等。 |
interval | 命令自动再次运行的时间间隔(以秒为单位)。 |
使用 Powershell 查看 Windows 监听端口
Get-NetTCPConnection cmdlet 是 PowerShell 中与 Netstat 命令相对应的命令。它能够查看与 Netstat 类似的信息。您可以使用 Get-NetTCPConnection
命令输出以下信息:
- 本地地址
- 本地端口
- 远程地址
- 远程端口
- 状态
1可以使用 Where-Object
过滤器对输出内容进行筛选,它类似于 findstr
命令:
Get-NetTCPConnection | Where-Object {$_.State -eq 'Listen'}
使用 PowerShell 查看 Windows 监听端口占用
2还可以使用 -State
参数按状态筛选连接列表:
Get-NetTCPConnection -State Listen
这将显示所有处于「监听」状态的端口。
3也可以使用端口号来应用筛选器:
Get-NetTCPConnection -LocalPort 22
4可以运行以下命令以获取每个连接的详细信息:
Get-NetTCPConnection | Select-Object -Property *
Get-NetTCPConnection 选择对象属性
Get-NetTCPConnection
与 Netstat
之间的主要区别在于,可以使用 Invoke-Command
命令远程调用。
PowerShell 还提供了另一个 GetNetStat
命令 ,用于在 Windows 以外的操作系统(如 Linux)上查看打开或监听的端口。GetNetStat 是一个跨平台模块,可在安装 PowerShell 的计算机上运行。