知乐空间

如何简单有效的查看windows进程使用了哪些端口(怎么查看电脑开启的端口)

对于运维来说,在排查网络问题时有时需要检查进程使用的端口,下面是一个bat脚本,主要是利用netstat命令找出使用TCP协议进行通信的端口,并对结果进行划分;将第二个参数(IP加端口)传递给%%i,将第五个参数(PID号)传递给% % j;

下面我们来介绍一下脚本的内容。

Bat脚本内容:

@echo off color 1f Title XP端口-进程查询 setlocal enabledelayedexpansion echo ╔- -╗ echo 本机开放的端口及使用该端口的进程 echo ╚- -╝ echo ------------------------------------ echo 端口号 进程名称 ECHO TCP协议: ::利用netstat命令找出使用TCP协议通信的端口,并将结果分割; ::将第二个参数(IP加端口)传给%%i,第五个参数(PID号)传给%%j; for /F "usebackq skip=4 tokens=2,5" %%i in (`"netstat -ano -p TCP"`) do (  call :Assoc %%i TCP %%j  echo !TCP_Port! !TCP_Proc_Name! ) ECHO UDP协议: for /F "usebackq skip=4 tokens=2,4" %%i in (`"netstat -ano -p UDP"`) do (  call :Assoc %%i UDP %%j  echo !UDP_Port! !UDP_Proc_Name! ) echo 按任意键退出 pause>nul :Assoc ::对%1(第一个参数)进行分割,将第二个参数传给%%e。在本程序中,%1即为上面的%%i(形式为:IP:端口号) for /F "tokens=2 delims=:" %%e in ("%1") do (  set %2_Port=%%e  ) :: 查询PID等于%3(第三个参数)的进程,并将结果传给变量?_Proc_Name,?代表UDP或者TCP; for /F "skip=2 usebackq delims=, tokens=1" %%a in (`"Tasklist /FI "PID eq %3" /FO CSV"`) do (  ::%%~a表示去掉%%a外面的引号,因为上述命令的结果是用括号括起来的。  set %2_Proc_Name=%%~a  )

这里只需要新建一个txt,复制上面的代码,修改名为bat(原txt)的后缀,然后右击以管理员身份运行即可。

运行结果:

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容,请发送邮件至 ZLME@xxxxxxxx@hotmail.com 举报,一经查实,立刻删除。

留言与评论(共有 0 条评论)
验证码: