联系我们联系我们
电子邮箱电子邮箱

检查本机开放的端口及端口对应进程的批处理

[复制链接]
  • TA的每日心情
    开心
    2018-10-19 14:24
  • 签到天数: 1 天

    [LV.1]初来乍到

    sean 发表于 2018-5-17 14:03:06
    465 0
    利用netstat命令找出使用TCP协议通信的端口,并将结果分割; 将第二个参数(IP加端口)传给%%i,第五个参数(PID号)传给%%j;

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

    (Linux学习网根据网络整理发布。)

    回复

    使用道具 举报

    您需要登录后才可以回帖 登录 | 立即注册

    本版积分规则

    发表新帖

    小黑屋|手机版|Archiver|华盟论坛 ( 京ICP证070028号 )

    Powered by 华盟网 X 8.0  © 2001-2013 Comsenz Inc.  华夏黑客同盟