批处理查询网吧系统的进程使用的TCP和UDP端口列表

本文讲述如何使用bat查询系统进程和端口号,并且以列表形式显示出来。

本文源码在WIN10网吧系统上运行通过。截图如下:

源码稍加改造可以显示出远程端IP地址,喜欢编程的可以自行修改。

源码分析:

核心功能使用netstat -ano -p TCP来查询占用了TCP端口的进程列表,获得进程的Pid

再调用子函数传递参数pid获取到进程的名称。

通过pid获取进程名称使用命令:"Tasklist /FI "PID eq %3",这里%3就是进程pid

源码和注释如下:


@echo off 
color a 
Title 天下网吧-进程查询批处理 
setlocal enabledelayedexpansion 
echo ╔-      txwb.com                      -╗ 
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=1 usebackq delims=, tokens=1" %%a in (`"Tasklist /FI "PID eq %3" /FO CSV"`) do ( 
   ::%%~a表示去掉%%a外面的引号,因为上述命令的结果是用括号括起来的。  
   set %2_Proc_Name=%%a 
  ) 


本文来源:天下网吧 作者:天下码农

声明
声明:本站所发表的文章、评论及图片仅代表作者本人观点,与本站立场无关。若文章侵犯了您的相关权益,请及时与我们联系,我们会及时处理,感谢您对本站的支持!联系Email:support@txwb.com,系统开号,技术支持,服务联系QQ:1175525021本站所有有注明来源为天下网吧或天下网吧论坛的原创作品,各位转载时请注明来源链接!
天下网吧·网吧天下
  • 本周热门
  • 本月热门
  • 阅读排行