[英]Detect if windows firewall is blocking my program
我有一個應用程序通過他們的 api 與 NetApp 設備進行通信。 在 Windows 防火牆打開的情況下,api 命令將失敗。 關閉防火牆后,api 命令可以工作。 我沒有收到“Windows 防火牆正在阻止此程序”之類的任何消息。
查看文檔,我相信我找到了需要打開才能使 api 命令工作的 TCP 端口。 如何以編程方式檢測端口是否被阻止,以便向用戶顯示有關潛在問題的消息?
防火牆管理器通過 COM 暴露自己並實現IsPortAllowed
。
我認為您可以這樣做:試一試:將 1433 更改為要檢查的端口。
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Net.Sockets;
namespace CheckPortStatus
{
class Program
{
static void Main(string[] args)
{
try
{
TcpClient tcp = new TcpClient();
tcp.Connect("localhost", Convert.ToInt16(1433));
Console.WriteLine("online");
}
catch (Exception ex)
{
Console.WriteLine("offline");
Console.WriteLine(ex.Message);
}
}
}
}
此外,要查看您的機器中可用的端口,請運行:
C:>netstat -an |find /i "listening"
TCP 0.0.0.0:25 0.0.0.0:0 監聽
TCP 0.0.0.0:80 0.0.0.0:0 監聽
TCP 0.0.0.0:135 0.0.0.0:0 監聽
要檢測端口是否被阻止 - 在 Win7 上,您可以通過打開 Windows 防火牆查看 Window 防火牆日志 - 單擊左側的高級設置,然后打開監控分支。
注意在日志設置部分的監控選項卡上有一個選項可以記錄到文件,在我的 Win7 PC 上是%systemroot%\\system32\\LogFiles\\Firewall\\pfirewall.log
- 你可以解析這個文件。 我過去研究過,有一些實用程序可以為您執行此操作,但是,歸根結底,它只是一個標准格式的日志文件。
我懷疑防火牆是否會提到它正在阻止應用程序,否則入侵者可以獲得有關阻止他訪問系統的信息:-)。
通常,防火牆會記錄與計算機之間的連接嘗試,無論成功與否,您都可以檢查它。
更新*
您可以嘗試在網絡中確認。 如果您在一定時間內沒有收到任何信息,那么您可以肯定地說連接存在問題。
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.