网管联盟 | 网管论坛 | 网管u家 | 网管博客 | 网管软件 | 网管求职 | 小游戏 | 网管搜索 | 网管原创 | 网管聚合 | 网管读摘 | 网管焦点 | 世界素材 | 会员投稿 | 会员中心 
中国网管联盟
Windows Linux Cisco 网络技术 数据库 黑客攻防 DotNet Java PHP 认证 新闻资讯 服务器 存储资讯 网络设备 网管学堂 技术专题 焦点 网吧频道
 当前位置: > bitsCN.com > DotNet > VC.NET > Visual C++制作一个Sniffer实例  

Visual C++制作一个Sniffer实例

2007-06-09  作者:bitsCN整理  来源:中国网管联盟  点评 投稿 收藏

  

  二、编程步骤

  1、启动Visual C++6.0,新建项目Snifpass,选择控制台模式。

  2、使用ClassWizard在项目中插入文件Snifpass.c;

  3、添加代码,编译运行程序。

  三、程序代码

中国网管论坛bbs.bitsCN.com

//////////////////////////////////////////////////////////////
#include <stdio.h>
#include <string.h>
#include <Winsock2.h>
#include <mstcpip.h>
#include "ws2tcpip.h"
#define MAX_PACK_LEN 4096 //接收的最大IP报文
#define MAX_ADDR_LEN 16 // 点分十进制地址的最大长度
#define MAX_HOSTNAME_LAN 255 //最大主机名长度
typedef struct _iphdr
{
 unsigned char h_lenver; //4位首部长度+4位IP版本号
 unsigned char tos; //8位服务类型TOS
 unsigned short total_len; //16位总长度(字节)
 unsigned short ident; //16位标识
 unsigned short frag_and_flags; //3位标志位
 unsigned char ttl; //8位生存时间 TTL
 unsigned char proto; //8位协议 (TCP, UDP 或其他)
 unsigned short checksum; //16位IP首部校验和
 unsigned int sourceIP; //32位源IP地址 网管联盟bitsCN_com
 unsigned int destIP; //32位目的IP地址
}IP_HEADER;
SOCKET SockRaw; int DecodeIpPack(char *,int); //IP解包函数
void CheckSockError(int,char*);//SOCK错误处理函数

void main(int argc, char ** argv)
{
 int iErrorCode;
 char RecvBuf[MAX_PACK_LEN] = {0};
 WSADATA wsaData;
 char name[MAX_HOSTNAME_LAN];
 struct hostent * pHostent;
 SOCKADDR_IN sa;
 DWORD dwBufferLen [10];
 DWORD dwBufferInLen = 1;
 DWORD dwBytesReturned = 0;

 if(argc!=1)
 {
  printf("Password sniffer written by Wu.\n\n");
  printf("Usage:");
  printf("\tsniffer.exe \n");
  exit(0);
 }
 printf("It's now sniffing,CTRL+C to exit...\n\n");
 //初始化SOCKET,建立一个原始套接字
 iErrorCode = WSAStartup(0x0202,&wsaData);
 CheckSockError(iErrorCode, "WSAStartup");
 SockRaw = socket(AF_INET , SOCK_RAW , IPPROTO_IP);
 CheckSockError(SockRaw, "socket");
 //获取本机IP地址
 iErrorCode = gethostname(name, MAX_HOSTNAME_LAN);
 CheckSockError(iErrorCode, "gethostname");

网管u家u.bitscn@com


 pHostent = (struct hostent * )malloc(sizeof(struct hostent));
 pHostent = gethostbyname(name);
 sa.sin_family = AF_INET;
 sa.sin_port = htons(6000);
 memcpy(&sa.sin_addr.S_un.S_addr, pHostent->h_addr_list[0], pHostent->h_length);
 //绑定套接字
 iErrorCode = bind(SockRaw, (PSOCKADDR)&sa, sizeof(sa));
 CheckSockError(iErrorCode, "bind");
 //设置SOCK_RAW为SIO_RCVALL,以便接收所有的IP包
 iErrorCode=WSAIoctl(SockRaw, SIO_RCVALL,&dwBufferInLen, sizeof(dwBufferInLen),
 &dwBufferLen, sizeof(dwBufferLen),&dwBytesReturned , NULL , NULL );
 CheckSockError(iErrorCode, "Ioctl");
 //侦听IP报文
 while(1)
 {
  memset(RecvBuf, 0, sizeof(RecvBuf));
  iErrorCode = recv(SockRaw, RecvBuf, sizeof(RecvBuf), 0);
  CheckSockError(iErrorCode, "recv");
  iErrorCode = DecodeIpPack(RecvBuf, iErrorCode);//对收到的IP包进行解包
  CheckSockError(iErrorCode, "Decode");
 }
}
//IP解包程序
int DecodeIpPack(char *buf, int iBufSize) 网管u家bitscn.net
{
 IP_HEADER *pIpheader;
 char *SearchPass;
 int iIphLen, iTTL;
 char szSourceIP[MAX_ADDR_LEN], szDestIP[MAX_ADDR_LEN];
 SOCKADDR_IN saSource, saDest;
 pIpheader = (IP_HEADER *)buf;
 //获取源IP地址
 saSource.sin_addr.s_addr = pIpheader->sourceIP;
 strncpy(szSourceIP, inet_ntoa(saSource.sin_addr), MAX_ADDR_LEN);
 //获取目标IP地址
 saDest.sin_addr.s_addr = pIpheader->destIP;
 strncpy(szDestIP, inet_ntoa(saDest.sin_addr), MAX_ADDR_LEN);
 iTTL = pIpheader->ttl;
 //计算IP包头长度
 iIphLen = sizeof(unsigned long) * (pIpheader->h_lenver & 0xf);
 SearchPass = buf + iIphLen + 20 ;
 //如果抓到密码就输出
 if(strstr(SearchPass,"pass")||strstr(SearchPass,"Pass")||strstr(SearchPass,"PASS"))
 {
  printf("\n\n%s->%s ", szSourceIP, szDestIP); //输出源计算机和目的计算机的IP地址
  printf("bytes=%d TTL=%d \n",iBufSize,iTTL);
  printf("%s",SearchPass);
 }
 return 0;
}
//SOCK错误处理程序
void CheckSockError(int iErrorCode, char *pErrorMsg) 网管u家www.bitscn.net
{
 if(iErrorCode==SOCKET_ERROR)
 {
  printf("%s Error:%d\n", pErrorMsg, GetLastError());
  closesocket(SockRaw);
  exit(0);
 }
}

  四、小结

  本实例首先介绍了以太网的工作方式,然后在此基础上实现网络嗅探程序,希望它对于那些对网络技术、黑客技术的读者朋友所有帮助。 网管联盟bitsCN_com

TAGs   实例   一个   制作   我们   iErrorCode   IP   //   char   int   Sniffer      
 上一篇:Visual C++编译器常用选项设置   下一篇:不同映射模式下的直线输出的效果问题
Visual C++制作一个Sniffer实例 评论:
loading.. 评论加载中…
评论:请自觉遵守互联网相关政策法规,评论不得超过250字。

验证码: 注册用户
本类热门排行:
最新推荐文章:
网管论坛交流: