web-dev-qa-db-ja.com

バッチファイルを使用してWindowsファイアウォールのポートを開く方法

バッチファイルを使用してWindows上の特定のポートを開く方法はありますか?ユーザーに手動で実行させるのではなく、インストーラーにサーバーアプリケーションに対してこれを実行させるのが良いでしょう。

14

netsh.exe を使用します。ポート引数を取るvery単純なバッチファイル:

@echo off
rem -- open port (first argument passed to batch script)
netsh advfirewall firewall add rule name="Open Port %1" dir=in action=allow protocol=TCP localport=%1 remoteip=10.15.97.0/24,10.17.0.0/16
20

これは、@ Kevin Richardsonが提供するソリューションの拡張です。 「netsh advfirewall add rule」コマンドは、同じコマンドを実行するたびに同じ名前で新しいルールを作成することに注意してください。以下のスクリプトはそれを防ぐのに役立ちます

ECHO OFF
set PORT=8081
set RULE_NAME="Open Port %PORT%"

netsh advfirewall firewall show rule name=%RULE_NAME% >nul
if not ERRORLEVEL 1 (
    rem Rule %RULE_NAME% already exists.
    echo Hey, you already got a out rule by that name, you cannot put another one in!
) else (
    echo Rule %RULE_NAME% does not exist. Creating...
    netsh advfirewall firewall add rule name=%RULE_NAME% dir=in action=allow protocol=TCP localport=%PORT%
)
11
Maxim Eliseev