cmd開啟任意埠的命令:電腦怎麼打開埠

概述

對於運維有時在排查網路問題時需要去查看進程使用的埠,下面整了一個bat腳本,主要利用netstat命令找出使用TCP協議通信的埠,並將結果分割;將第二個參數(IP加埠)傳給%%i,第五個參數(PID號)傳給%%j;

工作小技巧:windows環境如何查看進程使用的埠

下面介紹下腳本內容。


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 
 ) 
工作小技巧:windows環境如何查看進程使用的埠

在這裡大家只需要新建一個txt,複製上面代碼後修改後綴名為bat(本來為txt),然後右鍵以管理員身份運行就可以了。

工作小技巧:windows環境如何查看進程使用的埠

運行結果:

工作小技巧:windows環境如何查看進程使用的埠

原創文章,作者:投稿專員,如若轉載,請註明出處:https://www.506064.com/zh-tw/n/215681.html

(0)
打賞 微信掃一掃 微信掃一掃 支付寶掃一掃 支付寶掃一掃
投稿專員的頭像投稿專員
上一篇 2024-12-08 21:42
下一篇 2024-12-08 21:42

相關推薦

發表回復

登錄後才能評論