查看进程使用的端口
小软件基地整理发布
查看进程使用的端口,用于查看本机所有开放的端口以及端口所使用的进程名,您可以将下文字保存为批处理文件,也就是.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
)
本文链接:/Popular/2013/0412/process port.html
本文关键词: 进程
第二篇:查看进程使用的端口
@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。 在本程序中, 即为上面的%%i(形 %1 式为: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 )