2012-08-13 155 views
-3

我试图运行下面的perl脚本,但它显示一个错误。所需的文件是我把它们放在脚本文件的同一目录中。perl脚本显示错误:找不到文件

#! /usr/bin/perl 

@attackFileList=("_perParamDefaut_URLs.txt", "_perParam_URLs.txt", "_Cartesian_URLs.txt", "_Random_URLs.txt"); 
@legitFileList=("_Legit_URLs.txt"); 

$app=$ARGV[0]; 

print "Testing $app\n"; 
$startTime=time(); 
$attackCaught=$notCaught=$syntaxError=$other=$total=$error=$redirect=$success=0; 
for $fileEnding (@attackFileList) { 
    $fileName="$app$fileEnding"; 
    open(inputFile, "D:\\$app/$fileName") || die "Could not open $fileName\n"; 
    while ($line=<inputFile>) { 
     chomp $line; 
     @wget = split//, $line; 

     if ($wget[1] ne "--post-data") { 
         $wget[1] =~ s/"/\\"/g; 
       $wget[1] =~ s/`/\\`/g; 
       $wget[1] =~ s/_nosessions/_current/; 
       $wget[1] =~ s/endeavor.cc.gt.atl.ga.us/localhost:8080/; 
       $wget[1] =~ s/^\\"(.*)\\"$/"\1"/; 
       $command=$wget[0]." -O - "."\"".$wget[1]."\""; 
     } else { 
       $wget[2] =~ s/"/\\"/g; 
       $wget[2] =~ s/`/\\`/g; 
       $wget[3] =~ s/_nosessions/_current/; 
       $wget[3] =~ s/endeavor.cc.gt.atl.ga.us/localhost:8080/; 
      $wget[2] =~ s/^\\"(.*)\\"$/"\1"/; 
      $command=$wget[0]." -O - ".join(" ", $wget[1], $wget[2], $wget[3]); 
     } 

     $output=`$command 2>&1`; 
     $retValue=$?>>8; 
     if (($retValue == 0)||($output=~/302 Moved Temporarily/)) { 
      if ($output=~/amnesia\.SQLIAException/) { 
        $attackCaught++; 
       #print errorLog "PolicyViolationException:\n \t$wget[3]\n\t$wget[2]\n\t$command\n\n"; 
       } elsif ($output=~/amnesia\.UndetectedSQLIA/) { 
        $notCaught++; 
       print errorLog "UndetectedSQLIA:\n \t$wget[3]\n\t$wget[2]\n\t$command\n\n"; 
       } elsif ($output=~/lexer\.SQLLexerException/) { 
        $syntaxError++; 
       #print errorLog "SyntaxError:\n \t$wget[3]\n\t$wget[2]\n\t$command\n\n"; 
       } else { 
       if ($output=~/302 Moved Temporarily/) { 
        $redirect++; 
       } 
        $other++; 
      } 
      $success++; 
     } else { 
      $error++; 
     } 
     $total++; 
     if (($total % 100) == 0) {print "$total, ";} 
    } 
    close(inputFile); 
} 
print "\n"; 
$endTime=time(); 

$elapsedTime=$endTime-$startTime; 

print "**Testing Results: Attack**\n"; 
print "Total: $total\n"; 
print "\tValid URL requests: $success\n"; 
print "\t\tSQLIA detected: $attackCaught\n"; 
print "\t\tUndetected: $notCaught\n"; 
print "\t\tSyntax Errors: $syntaxError\n"; 
print "\t\tOther: $other\n"; 
print "\t\t\tRedirects: $redirect\n"; 
print "\tError URL requests: $error\n"; 
$omitted=$total-$error-$success; 
print "\tOmitted: $omitted\n"; 
print "\nTime: $elapsedTime seconds\n"; 

open (outFile, ">>Effective.results") || die "Could not open Effective.results\n"; 
print outFile "$app-attk\t$total\t$success\t$attackCaught\t$notCaught\t$syntaxError\t$other\t$error\t$omitted\n"; 
close(outFile); 

$startTime=time(); 
$attackCaught=$notCaught=$syntaxError=$other=$total=$error=$redirect=$success=0; 
foreach $fileEnding (@legitFileList) { 
    $fileName="$app$fileEnding"; 
    open(inputFile, "$app/$fileName") || die "Could not open $fileName\n"; 
    while ($line=<inputFile>) { 
     chomp $line; 
     @wget = split//, $line; 

     if ($wget[1] ne "--post-data") { 
      $wget[1] =~ s/"/\\"/g; 
       $wget[1] =~ s/`/\\`/g; 
      $wget[1] =~ s/_nosessions/_current/; 
      $wget[1] =~ s/endeavor.cc.gt.atl.ga.us/localhost:8080/; 
      $wget[1] =~ s/^\\"(.*)\\"$/"\1"/; 
        $command=$wget[0]." -O - "."\"".$wget[1]."\""; 
     } else { 
      $wget[2] =~ s/"/\\"/g; 
         $wget[2] =~ s/`/\\`/g; 
      $wget[3] =~ s/_nosessions/_current/; 
      $wget[3] =~ s/endeavor.cc.gt.atl.ga.us/localhost:8080/; 
      $wget[2] =~ s/^\\"(.*)\\"$/"\1"/; 
      $command=$wget[0]." -O - ".join(" ", $wget[1], $wget[2], $wget[3]); 
     } 

     $output=`$command 2>&1`; 
     $retValue=$?>>8; 
     if (($retValue == 0)||($output=~/302 Moved Temporarily/)) { 
      if ($output=~/amnesia\.SQLIAException/) { 
        $attackCaught++; 
       print errorLog "SQLIAException:\n\t$wget[3]\n\t$wget[2]\n\t$command\n\n"; 
       } elsif ($output=~/amnesia\.UndetectedSQLIA/) { 
        $notCaught++; 
       print errorLog "UndetectedSQLIA:\n \t$wget[3]\n\t$wget[2]\n\t$command\n\n"; 
       } elsif ($output=~/lexer\.SQLLexerException/) { 
        $syntaxError++; 
       print errorLog "SyntaxError:\n \t$wget[3]\n\t$wget[2]\n\t$command\n\n"; 
       } else { 
       if ($output=~/302 Moved Temporarily/) { 
        $redirect++; 
       } 
        $other++; 
      } 
      $success++; 
     } else { 
      $error++; 
     } 

     $total++; 
     if (($total % 100) == 0) {print "$total, ";} 
    } 
    close(inputFile); 

} 
print "\n"; 
$endTime=time(); 
close(errorLog); 
$elapsedTime=$endTime-$startTime; 

print "**Testing Results: Legit**\n"; 
print "Total: $total\n"; 
print "\tValid URL requests: $success\n"; 
print "\t\tSQLIA detected: $attackCaught\n"; 
print "\t\tUndetected: $notCaught\n"; 
print "\t\tSyntax Errors: $syntaxError\n"; 
print "\t\tOther: $other\n"; 
print "\t\t\tRedirects: $redirect\n"; 
print "\tError URL requests: $error\n"; 
$omitted=$total-$error-$success; 
print "\tOmitted: $omitted\n"; 
print "\nTime: $elapsedTime seconds\n"; 

open (outFile, ">>Effective.results") || die "Could not open Effective.results\n"; 
print outFile "$app-legit\t$total\t$success\t$attackCaught\t$notCaught\t$syntaxError\t$other\t$error\t$omitted\n"; 
close(outFile); 

电话: perl的script.bat门户

结果: 无法打开文件portal_perParamDefault_URLs.txt

+1

使用'$'知道为什么打开失败的原因:'死“无法打开$文件名:$!”;' – Toto 2012-08-13 09:32:56

+0

是的!我们都会放下一切,为你读几十行代码。如果你想在这里寻求帮助,你应该a)确保你使用'strict'和'warnings',b)要求Perl尽可能多地提供帮助(例如,在你的错误信息中使用'$ 1'开放“)和c)给我们提供你的程序的一小部分,因为我们需要了解你的问题。 – 2012-08-13 10:00:11

+0

你说文件和程序在同一个目录下。但是当你运行程序时,当前的工作目录是什么? – 2012-08-13 10:01:44

回答

1

Windows路径可以用斜杠,而不是反斜杠,或更好地利用File::Spec来处理它处理像:

my $full_path = File::Spec->catpath("D", $app, $fileName) 
open(inputFile, $full_path) or die $!; 
3

你的编码是可怕的,但我建议你的问题的答案可能是你的意思是_perParamDefault_URLs你有_perParamDefaut_URLs

之前要求别人饶恕自己的时间来帮助你,请有足够周到正确格式化您的代码,以便它是可读的,加use strictuse warnings你的程序的顶部,所有变量的使用my接近申报他们的第一个使用点。

您还应该使用词法文件句柄,open的三参数形式,并将$!变量添加到您的骰子字符串的内容中。一个样板调用open应该像

open my $fh, '<', $filename or die "Unable to open '$filename': $!";