io.pl
上传用户:rrhhcc
上传日期:2015-12-11
资源大小:54129k
文件大小:3k
源码类别:

通讯编程

开发平台:

Visual C++

  1. #!/usr/bin/perl -w
  2. #
  3. # Copyright (C) 2001 by USC/ISI
  4. # All rights reserved.
  5. #
  6. # Redistribution and use in source and binary forms are permitted
  7. # provided that the above copyright notice and this paragraph are
  8. # duplicated in all such forms and that any documentation, advertising
  9. # materials, and other materials related to such distribution and use
  10. # acknowledge that the software was developed by the University of
  11. # Southern California, Information Sciences Institute.  The name of the
  12. # University may not be used to endorse or promote products derived from
  13. # this software without specific prior written permission.
  14. #
  15. # THIS SOFTWARE IS PROVIDED "AS IS" AND WITHOUT ANY EXPRESS OR IMPLIED
  16. # WARRANTIES, INCLUDING, WITHOUT LIMITATION, THE IMPLIED WARRANTIES OF
  17. # MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE.
  18. #
  19. # An perl script that seperate inbound and outbound traffic of ISI domain, 
  20. # used by SAMAN ModelGen
  21. #
  22. # This work is supported by DARPA through SAMAN Project
  23. # (http://www.isi.edu/saman/), administered by the Space and Naval
  24. # Warfare System Center San Diego under Contract No. N66001-00-C-8066
  25. #
  26. sub usage {
  27.         print STDERR <<END;
  28. usage: $0 [-s DomainPrefix] [-w FilenameExtention]
  29. Options:
  30.     -s string  specify IP prefix to distinguish Inbound from outbound
  31.                traffic (eg. 192.1)
  32.     -w string  specify the filename extention
  33. END
  34.         exit 1;
  35. }
  36. BEGIN {
  37.      $dblibdir = "./";
  38.         push(@INC, $dblibdir);
  39. }
  40. use DbGetopt;
  41. require "dblib.pl";
  42. my(@orig_argv) = @ARGV;
  43. &usage if ($#ARGV < 0);
  44. my($prog) = &progname;
  45. my($dbopts) = new DbGetopt("s:w:?", @ARGV);
  46. my($ch);
  47. while ($dbopts->getopt) {
  48.      $ch = $dbopts->opt;
  49.         if ($ch eq 's') {
  50. $prefix = $dbopts->optarg;
  51. } elsif ($ch eq 'w') {
  52.         $fext = $dbopts->optarg;
  53.      } else {
  54.              &usage;
  55.         };
  56. };
  57. ($ip1,$ip2,$ip3,$ip4,$m1,$m2,$m3,$m4) = split(/[./ ]/,$prefix);
  58. $r1= 255 - $m1;
  59. $r2= 255 - $m2;
  60. $r3= 255 - $m3;
  61. $r4= 255 - $m4;
  62. $ip1h=$ip1+$r1;
  63. $ip2h=$ip2+$r2;
  64. $ip3h=$ip3+$r3;
  65. $ip4h=$ip4+$r4;
  66. if ($ip1h >  255) {
  67.    $ip1=0;
  68.    $ip1h=255;
  69. }   
  70. if ($ip2h >  255) {
  71.    $ip2=0;
  72.    $ip2h=255;
  73. }   
  74. if ($ip3h >  255) {
  75.    $ip3=0;
  76.    $ip3h=255;
  77. }   
  78. if ($ip4h >  255) {
  79.    $ip4=0;
  80.    $ip4h=255;
  81. }   
  82. $foutf=join(".",$fext,"outbound");
  83. $finf=join(".",$fext,"inbound");
  84. open(FOUT,"> $foutf") || die("cannot open $foutfn");
  85. open(FIN,"> $finf") || die("cannot open $finfn");
  86. while (<>) {
  87.         ($time1,$time2,$ip11,$ip12,$ip13,$ip14,$srcPort,$dummy1,$ip21,$ip22,$ip23,$ip24,$dstPort,$dummy2) = split(/[.:() ]/,$_);
  88. #        ($time1,$time2,$dummy0,$ip11,$ip12,$ip13,$ip14,$srcPort,$dummy1,$ip21,$ip22,$ip23,$ip24,$dstPort,$dummy2) = split(/[.:() ]/,$_);
  89. #        $dummy0="";
  90.         $dummy1="";
  91.         $dummy2="";
  92. $time1=0;
  93. $time2=0;
  94. $ip21="";
  95. $ip22="";
  96. $ip23="";
  97. $ip24="";
  98. $srcPort="";
  99. $dstPort="";
  100. # $prefixc=join(".",$ip11,$ip12);
  101.         #seperate Inbound and Outbound traffic of ISI
  102. # if ($prefixc eq $prefix) {
  103. if ((($ip11 <= $ip1h) && ($ip11 >= $ip1)) &&
  104.     (($ip12 <= $ip2h) && ($ip12 >= $ip2)) &&
  105.     (($ip13 <= $ip3h) && ($ip13 >= $ip3)) &&
  106.     (($ip14 <= $ip4h) && ($ip14 >= $ip4))) {
  107. print FOUT "$_";
  108. } else {
  109. print FIN "$_";
  110. }
  111. }
  112. close(FOUT);
  113. close(FIN);