查看: 1151|回复: 1
收起左侧

批处理查看进程端口.bat

[复制链接]
发表于 2013-10-12 11:09:28 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能,让你轻松玩转随县论坛。

您需要 登录 才可以下载或查看,没有账号?注册会员

×
  1. 用批处理实现的获取当前进程所开启的端口代码:

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


发表于 2013-11-26 07:22:03 | 显示全部楼层
您需要登录后才可以回帖 登录 | 注册会员

本版积分规则

快速入职
隐私保护
薪资透明
信息可靠
手机找工作

快速回复 返回顶部 返回列表