Windows Firewallで特定のアプリケーションの通信を許可するためのコマンドは、netsh
コマンドを使用します。以下に一般的な形式を示します:
netsh advfirewall firewall add rule name="My Application" dir=in action=allow program="C:\\\\Path\\\\To\\\\Your\\\\Application.exe" enable=yes
このコマンドは、指定したアプリケーション(ここでは "C:\Path\To\Your\Application.exe")への受信通信を許可する新しいルールを追加します。ルールの名前(ここでは "My Application")は、あなたが選ぶことができます。
このコマンドを実行するには、管理者権限が必要です。また、具体的なパスとアプリケーション名を指定する必要があります。
注意: この操作はシステムのセキュリティ設定を変更します。必要な場合にのみ行い、正確なパスとアプリケーション名を使用してください。不明な場合は、専門家に相談してください。また、この操作は自己責任で行ってください。私たちは、この操作によって生じる可能性のある問題については責任を負いません。
すでにWindows Firewallに特定のアプリケーションの通信を許可する設定が追加されているかどうかを確認するには、以下のコマンドを使用できます:
netsh advfirewall firewall show rule name="My Application" dir=in
このコマンドは、指定した名前(ここでは "My Application")の受信ルールを表示します。もしルールが存在すれば、その詳細が表示されます。
その結果を元に、以下のようなスクリプトを作成することで、ルールが存在しない場合にのみ新たなルールを追加することができます:
@echo off
netsh advfirewall firewall show rule name="My Application" dir=in >nul
if errorlevel 1 (
netsh advfirewall firewall add rule name="My Application" dir=in action=allow program="C:\\\\Path\\\\To\\\\Your\\\\Application.exe" enable=yes
)
このスクリプトは、指定した名前のルールが存在しない場合(netsh
コマンドがエラーレベル1を返す場合)にのみ、新たなルールを追加します。
注意: この操作はシステムのセキュリティ設定を変更します。必要な場合にのみ行い、正確なパスとアプリケーション名を使用してください。不明な場合は、専門家に相談してください。また、この操作は自己責任で行ってください。私たちは、この操作によって生じる可能性のある問題については責任を負いません。
もちろんです。以下に、PowerShellで同じ処理を行うスクリプトを示します:
$ruleName = "My Application"
$programPath = "C:\\\\Path\\\\To\\\\Your\\\\Application.exe"
$ruleExists = (netsh advfirewall firewall show rule name=$ruleName dir=in) -match "OK."
if (-not $ruleExists) {
netsh advfirewall firewall add rule name=$ruleName dir=in action=allow program=$programPath enable=yes
}
このスクリプトは、指定した名前のルールが存在しない場合にのみ、新たなルールを追加します。
注意: この操作はシステムのセキュリティ設定を変更します。必要な場合にのみ行い、正確なパスとアプリケーション名を使用してください。不明な場合は、専門家に相談してください。また、この操作は自己責任で行ってください。私たちは、この操作によって生じる可能性のある問題については責任を負いません。