对"查看进程使用的端口"工具小析

看后很受启发,来共享一下

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

乍一看觉得很复杂,仔细看看,其实作者只用了两个命令:netstat -ano -p和for的循环切割,大家可以去DOS中试试netstat -ano -p看看是什么效果,能看到很多关于进程、端口、协议的信息,只要合理的分割就能达到作者的效果,这个例子中还有很多值得学习的地方,比如setlocal enabledelayedexpansion变量延迟,对于这个代码而言也就是说凡是要在for语句后,再次调用你原先定义的变量你就要用变量延迟,这个还需要慢慢理解。



本文转自sucre03 51CTO博客,原文链接:http://blog.51cto.com/sucre/416083,如需转载请自行联系原作者


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值