|
- 在桌面空白处鼠标右键,弹出的菜单指向“新建”,在下一级菜单中单击“文本文档”
- 打开新建的文本文档,将下面的代码复制进去
@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
)
- 单击“文件”菜单中的“另存为”命令
- 选择好要保存批处理文件的路径,在文件名文本框中输入后缀名为bat的任意称号 ,单击“保存”按钮
- 这时在保存的位置会生成该bat文件,双击运行
- 运行批处理后就能查看到本机开放的端口及使用该端口的进程,如图[ghost win7纯净版]所示[win7旗舰版系统下载] :
|
|
|
|
|
|
|