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

📄 examineiv.pl

📁 This a good VPN source
💻 PL
字号:
#!/usr/bin/perl$inpacket=0;$firstpacket=1;$debug=0;sub extractlastcipherblock {  my(@bytes_last_two, @bytes_last_three, @bytes, $len, @iv);  print STDERR "LAST2: $lastPacketLine2" if $debug;  print STDERR "LAST3: $lastPacketLine3" if $debug;  @bytes_last_two   = split(/\s+/,$lastPacketLine2);  @bytes_last_three = split(/\s+/,$lastPacketLine3);    # get rid of offset  shift @bytes_last_two;  shift @bytes_last_three;  # get rid of text at right  pop @bytes_last_two;  pop @bytes_last_three;  @bytes = (@bytes_last_three, @bytes_last_two);    # now skip the last 12 bytes as the AUTH MAC.  # sizes halved because bytes are presented as 16-items  $len = $#bytes;  print STDERR "EXTRACT: ".($len-9)."-".($len-6)." of ",join('|',@bytes)."\n" if $debug;  @cbcbytes = @bytes[($len-9)..($len-6)];    $cbc = join('',@cbcbytes);  $myiv= $first4IV.$last4IV;    print STDERR "MyIV: ".$myiv." LastCBC: $cbc\n" if $debug;  if($myiv eq $cbc) {    print $packetHead." IV PREDICTED\n";  } else {    print $packetHead." IV PROBABLY RANDOM\n";  }}while(<>) {  $lastthree = $lasttwo;  $lasttwo   = $last;  $last      = $_;  if(/^IP \d*\.\d*\.\d*\.\d* \> \d*\.\d*\.\d*\.\d*\: ESP/) {    $packetnum++;    # save the lines of the previous packet    $lastPacketLine2 = $lasttwo;    $lastPacketLine3 = $lastthree;    $packetHead = $_;    chop($packetHead);    print STDERR "PACKET: $_" if $debug;    next;  }  if(/^\s+0x0000/) {    $inpacket=1;    next;  }    if(/^\s+0x0010/) {      print STDERR " FIRST: $_" if $debug;    @bytes=split(/\s+/,$_);    $first4IV = $bytes[7].$bytes[8];    next;  }  if(/^\s+0x0020/) {       print STDERR "SECOND: $_" if $debug;    @bytes=split(/\s+/,$_);    $last4IV = $bytes[1].$bytes[2];    if($packetnum > 1) {      &extractlastcipherblock;    }    next;  }}

⌨️ 快捷键说明

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