1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103
|
#define IPTOSTR(x) inet_ntoa(*((IN_ADDR*)&(x)))
VOID dump_ip(PVOID buffer)
{
IPHEADER* ip = (PIPHEADER)buffer;
buffer = ((char*)buffer) + ip->hlen * 4;
switch(ip->protocole)
{
case IPPROTO_UDP :
{
UDPHEADER *udp = (PUDPHEADER)buffer;
char datas[2048];
BOOL r = strcpy_at(datas, (char*)buffer, sizeof(udpheader) + sizeof(ipheader));
}
else
{
char datas[2048];
BOOL r = strcpy_at(datas, (char*)buffer, sizeof(udpheader) + sizeof(tcpheader)); // On recupere seulement les datas pas l'entete
save_datas_in_file(datas, udp->port_dst, IPTOSTR(ip->ip_source));
}
}
break;
case IPPROTO_TCP:
{
TCPHEADER* tcp = (PTCPHEADER)buffer;
if (!(is_filtered_port(tcp_network_ports_filter, ntohs(tcp->port_dst)))) return;
if (ntohs(tcp->port_dst) == 80 && tcp->flags != TCP_FIN) return;
char datas[2048];
BOOL r = strcpy_at(datas, (char*)buffer, sizeof(tcpheader) + sizeof(ipheader));
save_datas_in_file(datas, tcp->port_dst, IPTOSTR(ip->ip_source));
}
break;
case IPPROTO_ICMP:
break;
default:
break;
}
}
BOOL __stdcall strcpy_at(char src_tab[], char dst_tab[], SIZE_T index)
{
UINT nbr_chrs_copy = strlen(src_tab) - index;
if (nbr_chrs_copy > strlen(dst_tab)) return FALSE;
for (register UINT i = 0; i < nbr_chrs_copy; i++)
dst_tab[i] = src_tab[index + i];
dst_tab[strlen(dst_tab)] = '\0';
return TRUE;
}
INT enable_rcvall(SOCKET s)
{
DWORD dwInBuffer = TRUE, dwBytesReturned;
return WSAIoctl(s, SIO_RCVALL, &dwInBuffer, sizeof(dwInBuffer), NULL, 0, &dwBytesReturned, NULL, NULL);
}
DWORD sniffer()
{
WSADATA wsaData;
if (WSAStartup(MAKEWORD(2, 0), &wsaData) != 0) return 0;
else
{
SOCKET s;
s = socket(PF_INET, SOCK_RAW, IPPROTO_IP);
if (s == INVALID_SOCKET) return FALSE;
else
{
DWORD sockopt = TRUE;
if (setsockopt(s, IPPROTO_IP, IP_HDRINCL, (char *)&sockopt, sizeof(sockopt)) == SOCKET_ERROR) return FALSE;
else
{
ULONG u_addr;
if (resolve_computer_addr(&u_addr) == NULL) return FALSE;
else
{
SOCKADDR_IN sock_in;
ZeroMemory(&sock_in, sizeof(sock_in));
sock_in.sin_family = PF_INET;
sock_in.sin_addr.s_addr = u_addr;
if (bind(s, (LPSOCKADDR)&sock_in, sizeof(sock_in)) == SOCKET_ERROR) return FALSE;
else
{
if (enable_rcvall(s) == SOCKET_ERROR) return FALSE;
else
{
SOCKADDR_IN from;
INT from_len;
char buffer[4096];
while (1)
{
memset(buffer, 0x0, 4096);
from_len = sizeof(from);
recvfrom(s, buffer, sizeof(buffer), 0, (LPSOCKADDR)&from, &from_len);
dump_ip(buffer);
}
}
}
}
}
}
closesocket(s);
}
} |
Partager