在没有管理员帐户的情况下捕获原始套接字(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需要在本地计算机上的管理员权限。
要回答你的问题,没有管理员权限就无法完成。
所以没有办法捕获tcp数据包没有管理员权限,对不对? – technology
对。 (15个字符) –