当前位置: 首页 > 图文教程 > 脚本技术 > DOS/BAT > 本机开放的端口及使用该端口的进程的批处理

DOS/BAT
一个“灵异”批处理引发的思考加补充说明
批处理提取不同行上的内容的代码
windows 复制隐藏帐号完全批处理
使用regini.exe修改注册表命令
将bat文件注册为windows系统服务的方法
恶意软件\垃圾流氓通用反删除批处理文件
G8.3做的GHO G8.3不识别的问题的完美解决方案!
MD和RD命令的使用方法
DOS的启动过程详解分析
Msd、Undelete命令的使用方法
win32下的命令行集合
制作bat批处理和任意QQ号聊天!
用批处理实现将文件以数字重命名的代码
批处理之家发现的用批处理实现的系统类应用代码
纯脚本备份_还原驱动增强版附相关sleep.exe
批处理删除使用所有Windows Update功能的访问[图文+bat]
批处理 数码雨代码解释
按扩展名分类的批处理
批处理 网络配置信息查看器
获取文件更新列表 批处理

DOS/BAT 中的 本机开放的端口及使用该端口的进程的批处理


出处:互联网   整理: 软晨网(RuanChen.com)   发布: 2009-09-11   浏览: 90 ::
收藏到网摘: n/a

复制代码 代码如下:

@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
)