AXZ博客
给你海洋的知识 AXZLK.COM!

易语言伪造的ip协议怎么提交(在tcp/ip协议簇中ip是)

一段伪造IP的代码

源代码如下:

int TcpOptScan::send_tcp_raw( SOCKET sd, struct in_addr *srcAddr, struct in_addr *desAddr, u16 srcPort, u16 desPort, u32 seq, u32 ack, u8 flags, u16 window, u8 *options, int optlen, char *data, u16 datalen )

{

char *packet = new char[sizeof(IP_HEADER)+sizeof(TCP_HEADER)];

IP_HEADER *ip = (IP_HEADER *) 数据包;

TCP_HEADER *tcp = (TCP_HEADER*) (数据包 + sizeof(IP_HEADER));

psd_header *伪=新的psd_header;

u8 myttl = 128;

// 通过这些放置,我们可以获得数据和一些字段对齐易语言伪造的ip协议怎么提交,这样我们就不会在计算校验和时浪费太多

int res = -1;

结构 sockaddr_in 袜子;

int source_mallocated = 0;

// 检查是否是错误的地址

如果 (!desAddr || sd < 0 || !srcAddr)

在tcp/ip协议簇中ip是_tcp ip协议 ip协议称为_易语言伪造的ip协议怎么提交

{

删除数据包;

删除伪;

返回-1;

}

// 填写目标地址

sock.sin_family = AF_INET;

sock.sin_port = htons(desPort);

sock.sin_addr.S_un.S_addr = desAddr->s_addr;

//填写数据报

memset((char *) packet,0,sizeof(IP_HEADER) + sizeof(TCP_HEADER));

//填写IP数据报头

//填写IP头

ip->h_lenver=(4total_len=htons(sizeof(IP_HEADER)+sizeof(TCP_HEADER) +optlen + datalen);//16位总长度(字节)

ip->ident=0;//16位标识

易语言伪造的ip协议怎么提交_tcp ip协议 ip协议称为_在tcp/ip协议簇中ip是

ip->frag_and_flags=0;//3个标志位

ip->ttl=mytt​​l;//8位生存时间TTL

ip->proto=IPPROTO_TCP;//8位协议(TCP,UDP…)

ip->checksum=0;//16位IP头校验和

ip->sourceIP= srcAddr->s_addr;//32位源IP地址

ip->destIP= desAddr->s_addr;//32位目的IP地址

// 填写虚拟标题

伪->saddr = srcAddr->s_addr;

伪->daddr = desAddr->s_addr;

伪->ptcl = IPPROTO_TCP;

pseudo->tcpl = htons(sizeof(TCP_HEADER) + optlen + datalen);

伪->mbz=0;

//填写Tcp头

tcp->th_sport = htons(srcPort);

tcp->th_dport = htons(desPort);

如果(顺序)

{

tcp->th_seq = htonl(seq);

}

否则如果(标志和 TH_SYN)

{

tcp->th_seq = GetRadom();

}

如果(确认)

tcp->th_ack = htonl(ack);

tcp->th_lenres = (sizeof(TCP_HEADER)/4th_flag = 标志;

如果(窗口)

tcp->th_win = htons(窗口);

别的

tcp->th_win = htons(1024); /* 谁在乎 */

易语言伪造的ip协议怎么提交_在tcp/ip协议簇中ip是_tcp ip协议 ip协议称为

//复制数据

//如果(数据&&数据长度)

// memcpy(packet + sizeof(struct ip) + sizeof(struct tcphdr) + optlen, data, datalen);

/* 复制选项 */

//如果(可选)

// memcpy(packet + sizeof(struct ip) + sizeof(struct tcphdr), options, optlen);

//计算TCP校验和,计算校验和时需要包含TCP伪报头

无符号短牛;

niu=ntohs(ip->total_len);

char *SendBuf = new char[128];

memcpy(SendBuf,伪,sizeof(psd_header));

memcpy(SendBuf+sizeof(psd_header),tcp,sizeof(TCP_HEADER));

tcp->th_sum = checksum((USHORT*)SendBuf,sizeof(psd_header)+sizeof(TCP_HEADER)); //没有TCP数据

删除发送缓冲区;

//调试

int m = ntohs(ip->total_len);

int pr = ip->proto;

//调试

//ip->total_len=40;

res =sendto(sd,packet,ntohs(ip->total_len),0,(struct sockaddr*)&sock,sizeof(sock));

如果(res == SOCKET_ERROR)

{

字符 str_eror[50];

printf(" Raw socket sendto 发送数据失败易语言伪造的ip协议怎么提交,错误码: %d", GetLastError());

ReportStat(str_eror,0);

返回-1;

}

删除数据包;

删除伪;

返回资源;

}

赞(0)
未经允许不得转载:AXZ博客 » 易语言伪造的ip协议怎么提交(在tcp/ip协议簇中ip是)
分享到

评论 抢沙发

登录

找回密码

注册