在没有管理员帐户的情况下捕获原始套接字(SOCK_RAW)

问题描述:

我有以下代码,它捕获一些TCP数据包。但它要求程序以管理员身份运行。我如何修改此代码,以便即使使用非管理员帐户,该程序也可以工作?在没有管理员帐户的情况下捕获原始套接字(SOCK_RAW)

public void startSniffer() 
    { 
     bContinueCapturing = true; 

     mainSocket = new Socket(AddressFamily.InterNetwork, SocketType.Raw, ProtocolType.IP); 

     mainSocket.Bind(new IPEndPoint(IPAddress.Parse(Properties.Settings.Default.IPaddr), 0)); 
     mainSocket.SetSocketOption(SocketOptionLevel.IP, SocketOptionName.HeaderIncluded, true); 

     byte[] byTrue = new byte[4] { 1, 0, 0, 0 }; 
     byte[] byOut = new byte[4] { 1, 0, 0, 0 }; 


     mainSocket.IOControl(IOControlCode.ReceiveAll, byTrue, byOut); 

     mainSocket.BeginReceive(byteData, 0, byteData.Length, SocketFlags.None, new AsyncCallback(OnReceive), null); 

    } 

    public void OnReceive(IAsyncResult ar) 
    { 
     int nReceived = mainSocket.EndReceive(ar); 

     ParseData(byteData, nReceived); 

     if (bContinueCapturing) 
     { 
      byteData = new byte[4096]; 

      mainSocket.BeginReceive(byteData, 0, byteData.Length, SocketFlags.None, new AsyncCallback(OnReceive), null); 
     } 

    } 

MSDN's article on SIO_RCVALL,这是IOControlCode.ReceiveAll非托管相当于:

设置此IOCTL需要在本地计算机上的管理员权限。

要回答你的问题,没有管理员权限就无法完成。

+0

所以没有办法捕获tcp数据包没有管理员权限,对不对? – technology

+0

对。 (15个字符) –