#include#pragma comment(lib,"ws2_32.lib")
#pragma comment(lib,"libmySQL.lib")
using namespace std;
string str;//int转换为string后的字符串
char sql_query[1024];//保存MySQL语句
SOCKET sock;//声明socket
char hostName[128];//声明字符数组保存主机名
char buffer[65535];//设置缓冲区大小
hostent *pHostIP; //声明保存本机IP的结构体指针
MYSQL *conn;//声明数据库连接句柄
struct IP_HEAD
{
union
{
unsigned char Version;//版本(字节前4位)
unsigned char HeadLen;//首部长度(字节后4位)
};
unsigned char ServiceType;//服务类型
unsigned short TotalLen;//总长度(16位)
unsigned short Identifier;//标识符
union
{
unsigned short Flags;//标志位(字前位)
unsigned short FragOffset;//片偏移(后位)
};
unsigned char TimeToLive;//生存时间
unsigned char Protocol;//协议
unsigned short HeadChecksum;//头部校验和
unsigned int SourceAddr;//源IP地址
unsigned int DestinAddr;//目的IP地址
};
struct conn_info { //定义结构体,保存连接数据库需要的相关信息
char *host;
char *user;
char *password;
char *db;
};
MYSQL* mysql_conn_setup(conn_info con){
MYSQL* mysql=mysql_init(NULL);//初始化一个并返回一个新的MySQL对象
if(!mysql_real_connect(mysql,con.host,http://www.doczj.com/doc/6520f9eff7ec4afe05a1df8d.htmler,con.password,con.db,3306,NULL,0))//连接数据库
{
cout
}
return mysql;
}
void Start_()//启动winsock并创建Socket
{
WSADATA wsadata; //与Socket库绑定,建立一个WSADATA结构,wsaData用来存储系统传回的关于WINSOCK的资料
WSAStartup(MAKEWORD(2,2),&wsadata);
sock=socket(AF_INET,SOCK_RAW,IPPROTO_IP); //创建原始套接字
bool flag=TRUE;
setsockopt(sock,IPPROTO_IP,IP_HDRINCL,(char *)&flag,sizeof(flag));//(Socket描述符,通信协议,后三个指定操作)
}
void Fill_bind()//填充sockaddr_in并绑定socket
{
gethostname(hostName,100);//获取本地主机名
pHostIP=gethostbyname(hostName);//获取本机IP地址
sockaddr_in host_addr; //sockaddr_in结构的值必须是以网络字节顺序表示的值,不能直接使用本机字节顺序的值
host_addr.sin_family=AF_INET; //协议族 AF_INET
host_addr.sin_port=htons(6000); //honts函数可以将主机数据转换为网络字节顺序的数据
host_addr.sin_addr=*(in_addr *)pHostIP->h_addr_list[0];
bind(sock,(PSOCKADDR)&host_addr,sizeof(host_addr));//把原始Socket绑定到本地网卡
}
void Set_()//设置为混杂模式,截获流经网卡的所有IP数据报
{
DWORD dwValue=1;
DWORD dwBufferLen[10];
DWORD dwBufferInLen=1;
DWORD dwBytesReturned=0;
WSAIoctl(sock,_WSAIOW(IOC_VENDOR,1),&dwBufferInLen,s