Witaj Gościu! ( Zaloguj | Rejestruj )

Forum PHP.pl

4 Stron V   1 2 3 > »   
Reply to this topicStart new topic
> Bramka Gadu-Gadu
Seth
post 27.10.2002, 16:55:17
Post #1





Grupa: Przyjaciele php.pl
Postów: 2 335
Pomógł: 6
Dołączył: 7.03.2002

Ostrzeżenie: (0%)
-----


Nie wiem czy napisanie bramki Gadu-Gadu to znowuz taki trudny orzech do zgryzienia ale pomyslalem sobie, ze podziele sie moim doswiadczeniami w pisaniu tego skryptu. Skrypt bedzie nam sluzyl TYLKO do wysylania wiadomosci do uzytkownikow GG.

Protokol GG oparty jest na TCP/IP co ulatwia nam prace.
Aby polaczyc sie z serwerem GG nalezy uzyc funkcji fsockopen()
Kod
$fp = fsockopen( "appmsg.gadu-gadu.pl", 80, $errno, $errmsg, 3 );

pierwsza wartosc to nazwa hosta GG. Nastepna to nr. portu, kolejne dwie to stringi z bledami jezeli takowe sie pojawia, a ostatnia to liczba w sekundach timeoutu (opis funkcji fsocopen() znajduje sie tu).
Teraz musimy podszyc sie pod przegladarke i wyslac odpowiednie dane protokolem HTTP.
Kod
$get = "GET /appsvc/appmsg.asp?fmnumber=$UIN&version=$VERSION&fmt=$FORMAT&lastmsg=$MSG HTTP/1.0rn";

$get .= "Host: appmsg.gadu-gadu.plrn";

$get .= "User-Agent: Mozilla/4.0 (compatible; MSIE 5.0; Windows NT)rn";

$get .= "Pragma: no-cachern";



fputs($fp, $get);

$UIN - numer clienta
$VERSION - wersja clienta
$FORMAT - jest to wartosc oznaczajaca czy wiadomosc systemowa bedzie przesylana czystym textem ($FORMAT='') czy w HTMLu ($FORMAT != '') ja osobiscie nie uzywam formatu HTML i nie wiem jak go uzywac, wiec nie bede sie tym zagadnieniem zajmowal.
$MSG - numer ostatniej wiadomosci systemowej (zostawiamy pusta wartosc)

Serwer odpowie na to:
Cytat
HTTP/1.0 200 OK
...
0 217.17.41.84:8074 217.17.41.84

ostatni wiersz w kodzie pobieramy funkcja fgets()
Kod
$buf = fgets( $fp, 128 );

Uprzednio pomijajac pozostale linie.
Wiersz ten mowi nam o tym czy zawarta jest wiadomosc systemowa (0), nr. hosta wraz z portem pod jaki musimy sie podlaczyc, a ostatnia wartosc to sam IP hosta. Nas interesuje tylko IP hosta wraz z portem. Przyczym port 8074 nie jest jedynym do ktorego mozna sie podlaczyc. Wrazie bledu przy podlaczaniu sie do hosta mozna skorzystac z portu 443.
Teraz musimy wydobyc IP i port ze stringu. Nie bede tu podawal metody bo chyba kazdy wie jak to zrobic a sposobow jest wiele poczawszy od substr() (tongue.gif), explode() itp...
Przed lub po wydobyciu IP i portu mozemy (NIE MUSIMY) zamknac socket:
Kod
fclose($fp);

Teraz czas przyszedl na polaczenie sie z wlasciwym hostem umozliwiajacym nam wkoncu komunikacje w GG.
Kod
$fp = fsockopen( "217.17.41.85", 8074, $errno, $errmsg, 3 );

IP i port podalem w tej postaci, zeby zobrazowac jak to ma wygladac smile.gif
dodam jeszcze, czego nie powiedzialem wczesniej, ze po kazdym polaczeniu funkcja fsocopen() nalezy dodac kod zbezpieczajacy - obslugujacy blad wrazie gdyby nie mozna bylo sie polaczyc:
Kod
if( !$fp ){

  echo "blad";

}else{

...

dalsza czesc skryptu

...

Polaczywszy sie do hosta otrzymamy pakiet postaci:
Cytat
unsigned long typ
unsigned long rozmiar
unsigned long klucz

typ i rozmia nie bedzie nam potrzebny wiec pomijam jego opis.
Bedzie nam natomiast potrzebny klucz do stworzenia hasha hasla i przeslania go do hosta GG.
Do pobrania pakietu przeslanego od hosta po polaczeniu z nim uzyjemy funkcji unpack()
Kod
$data = fread($fp, 12);

if(!$data){

  echo "error";

}else{

  $hash_pack = unpack("Vtyp/Vrozmiar/Vklucz", $data);

  ...

Zmienna $hash_pack jest zmienna tablicowa, a jako, ze interesuje nas tylko klucz pobieramy z niej jego wartosc w nastepujacy sposob:
Kod
$key = $hash_pack['klucz'];

W opisie protokolu GG z ktorego korzystalem byl bledny algorytm uzywany do stworzenia hasha hasla, tak wiec po zmudnych poszukiwaniach natknalem sie na ten oto skrypt autorstwa Piotr Pawłowa:
Kod
function oblicz_hash_hasla($haslo, $klucz) {

    $temphi = 0;

    $templo = 1;

    for ($i = 0; $i < strlen($haslo); $i++) {

        $znak = ord($haslo[$i]);

        $templo *= $znak + 1;

        $temphi = ($temphi * ($znak + 1) + ($templo >> 16)) & 0xffff;

        $templo &= 0xffff;

    }

    $hashlo = $templo * ($klucz & 0x7fff);

    $hashhi = (($temphi * ($klucz & 0x7fff)) & 0xffff) + ($hashlo >> 16);

    $hashlo &= 0xffff;

    if ($klucz & 0x8000) {

        $hashlo += ($templo & 1) << 15;

        $hashhi += (($temphi & 1) << 15) + ($templo >> 1) + ($hashlo >> 16);

        $hashlo &= 0xffff;

    }

    $hashhi &= 0xffff;

    $hash = sprintf("%04x%04x", $hashhi, $hashlo);

    $hash = hexdec($hash);

    settype($hash, 'integer');



return $hash;

}

Do funkcji przesylamy haslo naszego konta bramki i klucz uzyskany wczesniej od hosta GG.
Teraz musimy wyslac pakiet do hosta:
Kod
fwrite($fp, pack("VVVVVVVv", 0x000c, 0x16, $gg_gate_uid, $hash, 0x0002, 0x0b, 0, 0));

$gg_gate_uid - nrume konta bramki
$hash - otrymany hash z funkcji oblicz_hash_hasla()
Teraz host zwroci nam odpowiedz na probe zalogowania w postaci
Cytat
unsigned long status_loginu
unsigned long rozmiar

Pobieramy go nastepujaco:
Kod
if( !$data = fread($fp, 8) ){

  echo "error";

}else{

...

dalsza czesc kodu

...

$data to interesujacy nas pakiet.
Teraz uzywajac funkcji unpack() pobieramy jego wartosc status_loginu
Kod
$pack = unpack("Vstatus_loginu/Vrozmiar", $data);

$status = $pack['status_loginu'];

Wartosci statusu mozemy zdefiniowac nastepujaco:
Kod
define("GG_LOGIN_OK", 0x0003);

define("GG_LOGIN_FAILED", 0x0009);

Nazwy mowia same za siebie smile.gif
Teraz jezeli zostalismy zalogowani(GG_LOGIN_OK) mozemy wyslac wiadomosc do uzytkownika GG.
Struktura pakietu z wiadomoscia do uzytkownika wyglada nastepujaco:
Cytat
unsigned long GG_SEND_MG
unsigned long rozmiar
unsigned long uid_odbiorcy
unsigned long seq
unsigned long classa_wiadomosci
unknown

unknow - niestety nie wiem co oznacza ta wartosc ale ustawiajac ja na 0(zero) mozna ja pominac w opisie winksmiley.jpg
GG_SEND_MSG ma wartosc:
Kod
define("GG_SEND_MSG", 0x000b);

rozmiar to dlugosc naszej wiadomosci. Uwaga wiadomosc nie moze byc wieksza niz 2000 znakow.
seq - numer sekwencji jest wykorzystywany przy potwierdzaniu dostarczenia lub zakolejkowaniu pakietu.
classa_wiadomosci - rodzaj wiadomosci, jeden z ponizszych:
Kod
define("GG_CLASS_QUEUED", 0x0001);

define("GG_CLASS_MSG", 0x0004); // wiadomosc w nowym oknie

define("GG_CLASS_CHAT", 0x0008); // wiadomosc jest czescia rozmowy

define("GG_CLASS_CTCP", 0x0010);

define("GG_CLASS_ACK", 0x0020);// bez potwierdzania wiadomosci


Kod wysylajacy pakiet jest nastepujacy:
Kod
mt_srand((double)microtime() * 1000000);

$seq = mt_rand();



$uin_odbiorcy = 'xxxx...'; // numer gg odbiorcy

$msg = ''; // wiadomosc do odbiorcy <= 2000 znakow



$data = pack("VVVVVa".strlen($msg)."C", GG_SEND_MSG, 0x0d + strlen($msg), $uin_odbiorcy,

        $seq, GG_CLASS_ACK, $msg, 0);



fwrite($fp, $data);

$msg - to oczywiscie wiadomosc dla odbiorcy
$uid_odbiorcy - nr gg odbiorcy

I oto wyslalismy wiadomosc do GG 8)

Na koniec pozostalo nam jeszcze wylogowanie sie:
Kod
define("GG_STATUS_NOT_AVAIL",0x0001);

define("GG_STATUS_AVAIL", 0x0002);



fwrite($fp, pack('VVV', GG_NEW_STATUS, 0x04, GG_STATUS_NOT_AVAIL););

fclose($fp);


Tak oto wyglada wysylanie wiadomosci do uzytkownikow GG. Z przykroscia musze powiedziec, ze strona z opisem protokolu GG ostatnio nie dziala ale jezeli sa to tylko chwilowe problemy warto na nia zajzec: www.dev.null.pl/ekg/docs/protocol.html

Opisany tu kod wymaga oczywiscie kilku zabiegow min. napisanie obslugi bledow, rozpisania wszystkiego na poszczegolne funkcje ew. napisania classy itp. Tak wiec jest to zarys skryptu bramki GG. Skrypt moze nie dzialac prawidlowo bo gdzies sie moglem rabnac (jestem tylko czlowiekem winksmiley.jpg), wiec zadawajcie pytania na forum.

PROSZE NIE PISAC ABYM PODAL CALY SKRYPT BRAMKI GDYZ WSZYSTKO ZOSTALO JUZ NAPISANE (TO CO MIALO BYC NAPISANE winksmiley.jpg ), WIEC NALEZY TYLKO WYTEZYC SZARE KOMORKI I WZIASC SIE DO PRACY winksmiley.jpg
Go to the top of the page
+Quote Post
em1X
post 30.01.2003, 00:03:33
Post #2





Grupa: Zarejestrowani
Postów: 984
Pomógł: 41
Dołączył: 16.03.2002
Skąd: Płock

Ostrzeżenie: (0%)
-----


eh a na http://gg.wha.la sa pelne zrodla smile.gif


--------------------
eh, co polska wódka to polska wódka
Go to the top of the page
+Quote Post
Seth
post 30.01.2003, 01:59:58
Post #3





Grupa: Przyjaciele php.pl
Postów: 2 335
Pomógł: 6
Dołączył: 7.03.2002

Ostrzeżenie: (0%)
-----


ehh ta bramka nie dziala dobrze... jezeli masz status inny niz dostepny lub zaraz wracam wiadomosc nie dotrze to adresata... moj kodzik dziala 100% 8)
Go to the top of the page
+Quote Post
kwiateek
post 30.01.2003, 12:18:49
Post #4





Grupa: Zarejestrowani
Postów: 223
Pomógł: 0
Dołączył: 13.01.2003
Skąd: 3rd ball of mud behind a big ball of burning gas

Ostrzeżenie: (0%)
-----


Cytat
ehh ta bramka nie dziala dobrze... jezeli masz status inny niz dostepny lub zaraz wracam wiadomosc nie dotrze to adresata... moj kodzik dziala 100%  8)

tesowalem tamto co podal em1X i przy statusie zaraz wracam chodzi... natomiast nie dziala przy niewidoczny.
Rozumiem Seth ze twoj chodzi nawet przy niewidoczny i nidostepny ?
Go to the top of the page
+Quote Post
Seth
post 31.01.2003, 21:20:35
Post #5





Grupa: Przyjaciele php.pl
Postów: 2 335
Pomógł: 6
Dołączył: 7.03.2002

Ostrzeżenie: (0%)
-----


tak
Go to the top of the page
+Quote Post
pm
post 6.03.2003, 15:38:43
Post #6





Grupa: Zarejestrowani
Postów: 8
Pomógł: 0
Dołączył: 6.03.2003

Ostrzeżenie: (0%)
-----


seth, bredzisz. "twoj" skrypt niczym sie nie rozni , po za tym bezczelnie spisales go z bramki www2gg, funkcja liczaca hash hasla byla tylko tam dostepna i nie podales zrodla.
A wysylanie wiadomosci w trybie niewidoczny jest zwiazane tylko z trescia i wyrazeniami "pl" "www" ktore www2gg filtruje.
Chciales sie popisac cudzym kodem, nie wyszlo, wstydz sie:)


--------------------
Go to the top of the page
+Quote Post
itsme
post 6.03.2003, 16:09:46
Post #7





Grupa: Zarząd
Postów: 1 512
Pomógł: 2
Dołączył: 22.04.2002
Skąd: Koszalin




Jedno pytanie jak mozna skopiowac kod php ?
co otwierasz strone i dajesz ^a ^c ^v ?
nalezy uwazac co sie mowi ... bez dowodow bym uwazal

Seth: daj te narzedzie ktorym kopiowales skrypty php smile.gif))
ehhhhhh dlaczego ten swiat jest pelen zawisci ?


--------------------
brak sygnaturki rowniez jest sygnaturką
Go to the top of the page
+Quote Post
pm
post 6.03.2003, 16:29:25
Post #8





Grupa: Zarejestrowani
Postów: 8
Pomógł: 0
Dołączył: 6.03.2003

Ostrzeżenie: (0%)
-----


itsme: może tak http://gg.wha.la/www2gg-2.0.tar.gz , trudne nie? fajne forum...


--------------------
Go to the top of the page
+Quote Post
itsme
post 6.03.2003, 16:41:35
Post #9





Grupa: Zarząd
Postów: 1 512
Pomógł: 2
Dołączył: 22.04.2002
Skąd: Koszalin




pm: wlasnie tak ... argumenty sa podstawa zarzutow nic innego


--------------------
brak sygnaturki rowniez jest sygnaturką
Go to the top of the page
+Quote Post
Seth
post 6.03.2003, 18:12:52
Post #10





Grupa: Przyjaciele php.pl
Postów: 2 335
Pomógł: 6
Dołączył: 7.03.2002

Ostrzeżenie: (0%)
-----


angrysmiley.gif
nie kopjowaem zadnego kodu, funkcje do hashowania hasla podeslal mi qmpel.

A tak wogole to moge juz udostepnic jej skrypt, wiec zobacz cwe** czy ten kod jest podobony:

[php:1:02a64d5d13]<?php
// gg_gate class v1.9
// Copyright©2002/2003 by Michal 'Seth' Golebiowski
// E-Mail: sethmail@poczta.fm
// All rights reserved

define( 'GG_LOGIN', 0x000c );
define( 'GG_STATUS_AVAIL', 0x0002 );
define( 'GG_LOGIN_OK', 0x0003 );
define( 'GG_SEND_MSG', 0x000b );
define( 'GG_CLASS_MSG', 0x0004 );
define( 'GG_NEW_STATUS', 0x0002 );
define( 'GG_STATUS_NOT_AVAIL', 0x0001 );

// Classa bramki gg
class gg_gate{
var $to = ''; // uin gg adresata
var $msg = ''; // wiadomosc do adresata
var $from = ''; // nadawca
var $debug_mode = 0; // tryb debugera
var $debug_log = array(); // tablica loga debugera
var $_inner_vars = array(); // wewnetrzne zmienne classy


function gg_gate( $to='', $msg='', $from='' ){
$this->to = $to;
$this->msg = $msg;
$this->from = $from;
$this->debug_mode = 0;
$this->debug_log = array();
$this->_inner_vars = array();

$this->_inner_vars['gate_uinpass'] = array( '12345' => 'xxx', '4335' => 'xxx' ); // uin i haslo konta
$this->_inner_vars['sys_msg'] = array(); // nr osatniej wiadomosci systemowej
}


// Debuger skryptu
// $debug_mode=
// 0 - wylaczony debuger
// 1 - wyswietlaj wiadomosci debugera i zapisuj do tablicy loga debugera ($debug_log)
// 2 - tylko wyswietlaj wiadomosci debugera
// 3 - tylko zapisuj do tablicy loga debugera ($debug_log)
function debug( $msg ){
if( $this->debug_mode == 0 ) return;

if( $this->debug_mode == 1 || $this->debug_mode == 2 )
echo "<b>DEBUG></b> $msg<br>";

if( $this->debug_mode == 1 || $this->debug_mode == 3 )
$this->debug_log[count( $this->debug_log )] = date("[H:i:s d/m/Y] ").$msg;
}


// Tworzenie hasha hasla
// Funkcja autorstwa: Piotra Pawłowa
function create_hash( $pass, $key ){
$x = 0;
$y = 1;

for( $i = 0; $i < strlen( $pass ); $i++) {
$char = ord( $pass[$i] );
$y *= $char + 1;
$x = ( $x * ( $char + 1 ) + ( $y >> 16)) & 0xffff;
$y &= 0xffff;
}

$y = $y * ( $key & 0x7fff );
$x = ( ( $x * ( $key & 0x7fff ) ) & 0xffff ) + ( $y >> 16 );
$y &= 0xffff;

if( $key & 0x8000 ){
$y += ( $y & 1 ) << 15;
$y += ( ( $x & 1 ) << 15 ) + ( $y >> 1 ) + ( $y >> 16 );
$y &= 0xffff;
}

$x &= 0xffff;
$hash = sprintf( "%04x%04x", $x, $y );
$hash = hexdec( $hash );
settype( $hash, 'integer' );

return $hash;
}


// Pobieranie tablicy wiadomosci systemowych dla odpowiednich uin'ow
function system_msg( $mode ){
if( $mode == 'get' ){
$this->debug( 'Pobieranie listy wiadomosci systemowych...' ); // debug

$lines_array = @file( 'data/sys_msg.dat' );

foreach( $lines_array as $line ){
$vals = explode(':', $line);
if( $vals[0] != '' || $vals[1] != '' ) $this->_inner_vars['sys_msg']["$vals[0]"] = $vals[1];
}
}elseif( $mode == 'put' ){
$this->debug( 'Zapisywanie listy wiadomosci systemowych...' ); // debug

$fp = fopen( 'data/sys_msg.dat', 'w' );
flock( $fp, 2 );
foreach( $this->_inner_vars['sys_msg'] as $uin => $msg_no ){
if( $uin != '' || $msg_no != '' ) fwrite( $fp, $uin.':'.$msg_no."rn" );
}
flock( $fp, 3 );
fclose( $fp );
}

$this->debug( '...zakonczone' ); // debug
}


// Pobieranie hosta i portu
function get_host( &$host, &$port, $uin = 0, $msg_no = 0 ){
$this->debug( 'Laczenie z hostem...' ); // debug
$fp = @fsockopen( 'appmsg.gadu-gadu.pl', 80, $errno, $errmsg, 3 );

if( !$fp ){
$this->debug( '...niepowiodlo sie [!]' ); // debug
return 0;
}else{
$this->debug( '...zakonczone sukcesem' ); // debug
}

$get = "GET /appsvc/appmsg2.asp?fmnumber=$uin&version=5%2C+0%2C+1%2C+76&fmt=&lastmsg=$msg_no HTTP/1.0rn";
$get.= "Host: appmsg.gadu-gadu.plrn";
$get.= "User-Agent: Mozilla/4.7 [en] (Win98; I)rn";
$get.= "Pragma: no-cachernrn";
@fwrite( $fp, $get );

$this->debug( 'Pobieranie IP i portu...' ); // debug
if( !$buf = fread( $fp, 300 ) ){
@fclose( $fp );
$this->debug( '...polaczenie zerwane [!]' ); // debug
return 0;
}

$tmp = explode( "rn", $buf );
list( $new_msg_no, $host, $port ) = split( '[ :]', ( $msg_no != null ? $tmp[0] : $tmp[5] ) );

if( is_numeric( $new_msg_no ) ){
$this->_inner_vars['sys_msg']["$uin"] = $new_msg_no;
}else{
$this->_inner_vars['sys_msg']["$uin"] = 0;
}

if( !is_numeric( $port ) ){
$this->debug( '...blad danych [!]' ); // debug
return 0;
}else{
$this->debug( '...zakonczone sukcesem' ); // debug
}

fclose( $fp );

return 1;
}


// Logowanie do serwera gg
function logon( &$fp, $uin, $pass, $msg_no ){
if( !$this->get_host( $host, $port, $uin, $msg_no ) ){
$host = '217.17.41.'.rand( 86, 89 ); // Losowanie domyslnego host
$port = 8074; // Domyslny port hosta
$this->debug( "Wybrano domyslnego hosta $host:8074
[*]" ); // debug
}

$this->debug( "Laczenie z $host:$port..." ); // debug
$fp = @fsockopen( $host, $port, $errno, $errmsg, 3 );

if( !$fp ){
$this->debug( '...nie mozna nawiazac polaczenia [!]' ); // debug
return 0;
}
$this->debug( '...zakonczone sukcesem' ); // debug

if( !$data = @fread( $fp, 12 ) ){
@fclose( $fp );
$this->debug( 'Polaczenie zerwane [!]' ); // debug
return 0;
}

$packet = unpack( "V/V/Vkey", $data );
$hash = $this->create_hash( $pass, $packet['key'] );

$this->debug( 'Logowanie do hosta...' ); // debug
@fwrite( $fp, pack( "VVVVVVVv", GG_LOGIN, 0x16, $uin, $hash, GG_STATUS_AVAIL, 0x0b, 0, 0 ) );

if( !$data = fread( $fp, 8 ) ){
@fclose( $fp );
$this->debug( '...polaczenie zerwane [!]' ); // debug
return 0;
}

$packet = unpack("Vstatus/V", $data);

if( $packet['status'] == GG_LOGIN_OK ){
$this->debug( '...zakonczone sukcesem' ); // debug
return 1;
}else{
@fclose( $fp );
$this->debug( '...logowanie niepowiodlo sie [!]' ); // debug
return 0;
}
}


// Wysylanie wiadomosci
// zwraca:
// 0 - nie wylasno wiadomosci
// 1 - wiadomosc wyslano
function send_msg(){
$err_level = error_reporting();
error_reporting(0); // tymczasowe wylaczenie bledow

$this->system_msg( 'get' );

foreach( $this->_inner_vars['gate_uinpass'] as $uin => $pass ){
$this->debug( 'Logowanie na konto: '.$uin.' [~]' ); // debug

for( $i = 3; $i >= 1; $i-- ){ // 3 proby zalogowania sie do hosta w razie bledow
if( $this->logon( $fp, $uin, $pass, $this->_inner_vars['sys_msg']["$uin"] ) ) break;
if( $i == 1 ){
$this->debug( 'Proby zalogowania do hosta niepowiodly sie [!]' ); // debug
}
}

if( $fp ) break;
}

if( !$fp ){
error_reporting( $err_level );

return 0;
}

mt_srand( ( double ) microtime() * 1000000 );
$seq = mt_rand();

$msg = "{$this->msg}rnWiadomość od: {$this->from}rnrnWiadomość wysłana z bramki Gadu-Gadu";
$msg = strtr( $msg, "xA1xA6xACxB1xB6xBC", "xA5x8Cx8FxB9x9Cx9F" );
$msg_len = strlen( $msg );

$this->debug( "Wyslano wiadomosc do {$this->to}" ); // debug
@fwrite( $fp, pack( "VVVVVa".$msg_len."C", GG_SEND_MSG, 0x0d + $msg_len, $this->to, $seq, GG_CLASS_MSG, $msg, 0 ) );

$this->logoff( $fp );
$this->system_msg( 'put' );

error_reporting( $err_level );

return 1;
}


// Wylogowanie
function logoff( &$fp ){
@fwrite( $fp, pack( "VVV", GG_NEW_STATUS, 0x04, GG_STATUS_NOT_AVAIL ) );
@fclose( $fp );
$this->debug( 'Wylogowano z konta [~]' ); // debug
}
}
?>[/php:1:02a64d5d13]

Jezeli nie masz 100% pewnosci swoich sadow nie [ciach] glupot i nie obrazaj ani nie oskarzaj innych :!: angrysmiley.gif angrysmiley.gif angrysmiley.gif
Go to the top of the page
+Quote Post
pm
post 6.03.2003, 19:17:38
Post #11





Grupa: Zarejestrowani
Postów: 8
Pomógł: 0
Dołączył: 6.03.2003

Ostrzeżenie: (0%)
-----


ah tak, "kumpel" podeslal , podzial funkcji jest identyczny, konsturcje pack/unpack tez , losowanie hosta... tylko nazwy i komunikaty zmienione, ale moze kazdemu by wyszedl by taki sam uklad gdyby sie za to zabral:) funkcja liczaca hash jest zywcem z www2gg (tak wiem - kumpel podeslal)

Wiec wszystkie obelgi dotycza owego tajemniczego "kumpla" ktory zachowal sie nieładnie a Ty jestes oczywiscie czysty, niedobry ten kumpel fe;)


--------------------
Go to the top of the page
+Quote Post
Seth
post 6.03.2003, 19:30:15
Post #12





Grupa: Przyjaciele php.pl
Postów: 2 335
Pomógł: 6
Dołączył: 7.03.2002

Ostrzeżenie: (0%)
-----


A dlaczego niby konstrukcje packa mialy by byc inne ? Chyba korzystales z tego samego opisu protokolu co ja ?

Chcesz czy nie chcesz wierzyc ale kod napisalem sam korzystajac z protokolu gg opisanego na podanej przezmnie stronce + troche wlasnej inwencji. Co do hashowania hasla to jest on taki sam gdyz owy kolega podeslal mi jego kod po tym jak zapytalem sie czy nie wie jak to rozgryzc. Przyczym jeszcze dodam, ze nie jest wykluczone, a nawet jest pewne, ze wyciagnal on ze skryptu z www2gg. Ale pwoedz mi jedno... po co niby mial bym umieszczac autora tej funkcji gdybym zerznal toczka w toczka kod z www2gg ? Przeciez kazdy odrazu by sie kapnal.
Jeszcze jedno, ten skrypt na www2gg ma jakis blad, ktory nie wysyla wiadomosci jezeli uzytkownik nie jest dostepny lub zaraz wracam. Czy wiec przepisanie calego kodu i ew zmienienie jego fragmentow nie wiazalo by sie z powieleniem owego bledu ?
Misiek... rozumiem, ze moze sie wydac, ze skoro juz ktos udostepnia kod to wiekszosc chca go zerznac i podpisac sie pod nim ale bynajmniej nie kazdy ma tego typu aspiracje.
Zabaloalo mnie tylko jedno... to, ze po kilku nocach spedzonych nad pisaniem tego kodu ktos uwaza mnie za zlodzieja.
Go to the top of the page
+Quote Post
pm
post 6.03.2003, 20:08:15
Post #13





Grupa: Zarejestrowani
Postów: 8
Pomógł: 0
Dołączył: 6.03.2003

Ostrzeżenie: (0%)
-----


Dobra pokój, możemy normalnie pogadać.

>
Cytat
A dlaczego niby konstrukcje packa mialy by byc inne ?
> Chyba korzystales z tego samego opisu protokolu co ja ?

tak, napisalem to w październiku 2001... od tego czasu wyszło pare aktualizacji, zrobienie każdej nowe wersji zajeło mi 1 dzień

> Chcesz czy nie chcesz wierzyc ale kod napisalem sam korzystajac z
> protokolu gg opisanego na podanej przezmnie stronce + troche wlasnej

W tym protokole też mam pewien udział. dziwi mnie skąd wziałeś
akurat wersje 0x0b klienta do której pasuje ten hash obecnie w opisie protokolu jest nowy pasujacy do wersji >0x14 dziwnym zbiegiem www2gg 1.4 (na której jak wczesniej podejrzewałem bazował ten skrypt) używa też 0x0b, do tego te konstrukcje $host = '217.17.41.'.rand( 86, 89 ); tez podobne , 3 proby logowania..., ale niech bedzie wykazujac dobra wole jestem w stanie uwierzyc w zbieg okolicznosci.


> inwencji. Co do hashowania hasla to jest on taki sam gdyz owy kolega
> podeslal mi jego kod po tym jak zapytalem sie czy nie wie jak to
> rozgryzc. Przyczym jeszcze dodam, ze nie jest wykluczone, a nawet jest
> pewne, ze wyciagnal on ze skryptu z www2gg. Ale pwoedz mi jedno...
> po co niby mial bym umieszczac autora tej funkcji gdybym zerznal
> toczka w toczka kod z www2gg ? Przeciez kazdy odrazu by sie kapnal.

ok, dziwie sie jeszcze, że nie znales tego skryptu wczesniej, google zwraca 1500 trafien na www2gg, jest w downlodach paru stron o php. Ze nawet kolega podsyłając hash nie powiedział skąd jest.

> Jeszcze jedno, ten skrypt na www2gg ma jakis blad, ktory nie wysyla
> wiadomosci jezeli uzytkownik nie jest dostepny lub zaraz wracam. Czy
> wiec przepisanie calego kodu i ew zmienienie jego fragmentow nie
> wiazalo by sie z powieleniem owego bledu ?

Ten "blad" nie dotyczy skryptu a praktycznie kazdego klienta gadu gadu
wysylajac w trybie offline a wiec i invisible wiadomosc zawierajaca linki lub
adresy www i email zostanie ona odfiltorowana przez serwer gg jako spam
(co jest bardzo glupie z ich strony ale coż) skrypt w wersji 2.0 radzi sobie z tym podmieniajac te wyrazenia na inne i unika odfiltorowania ( w wersji 1.4 tez to robil ale filtry ulegly zmianie stad zauwazone przez Ciebie niedziałanie w trybie offline i invisible) Twoja wersja jesli nie podmienia tych wyrazen w textach tez musi sie charakteryzowac podobna wlasciwoscia. Jest to zwiazane rozniez z trzymanien na liscie kontaktow numeru bramki wiec czasami trudno dojsc przyczyn.

> Misiek... rozumiem, ze moze sie wydac, ze skoro juz ktos udostepnia
> kod to wiekszosc chca go zerznac i podpisac sie pod nim ale bynajmniej
> nie kazdy ma tego typu aspiracje.

Niestety juz ktos tak kiedys zrobil, chyba jakis velo ze scrypty.com lub scryty.net (juz nie pamietam www) po prostu umiescil w downloadzie moj skrypt podpisujac sie wszedzie swoim nickiem , ale po mojej reakcji szybko to usunal.

> Zabaloalo mnie tylko jedno... to, ze po kilku nocach spedzonych nad
> pisaniem tego kodu ktos uwaza mnie za zlodzieja.


Złożyło sie na to zbyt wiele jak sie okazuje zbiegów okolicznosci i nie wspomnienia o www2gg w pierwszym poscie,
nie uważam Cie za złodzieja i proponuje pokój:)


--------------------
Go to the top of the page
+Quote Post
Seth
post 6.03.2003, 22:04:56
Post #14





Grupa: Przyjaciele php.pl
Postów: 2 335
Pomógł: 6
Dołączył: 7.03.2002

Ostrzeżenie: (0%)
-----


Pokoj przyjety smile.gif
Wiec na wstepie chce powiem, ze doskonale Cie rozumiem. Sam nie lubie jak ktos wykorzystuje cudza prace. Po moim pierwszym poscie mozna bylo wysnuc wrazenie, ze opisuje twoj skrypt, wiec dlatego udostepnilem tu swoj.

Co do wersji 0x0b to wlasnie dzieki niej dochodza wiaodmosci nawet jak uzytkownik ma 'nie ten' status. Doszedlem do tego przez przypadek.

Co do 3 logowan: pisalem juz kilka aplikacji client-server i zawsze po 3ech nieudanych probach logowania wywalalem blad, wiec to ile razy sie pruboje logowac to poprostu kwestia przyzwyczajenia. Zauwaz jeszcze, ze tak naprawde nie sa to tylko 3 logowania a w tym przypadku 6, gdyz na poczatku podalem 2 uiny bramek. Czyli jezeli na pierwsza po3ech logowaniach nie da sie wejsc to wchodzimy na druga.

Co do Twojego skryptu: to wzasadzie traf chcial, ze zainteresowalem sie protokolem gg. Kiedys na jakiejs stronie znalazlem link do zrodel gg i miedzy innymi do protokolu gg (nie mowie tu o Twojej stronie tylko o: http://www.dev.null.pl/ekg/). A ze wlasnie skonczylem pisac bramki sms, pomyslalem sobie, ze fajnie bylo by umiescic jeszcze bramke gg.

To, ze nie wspomnialem o www2gg jest byc moze bledem ale nie chcialem aby ludzie odrazu szli na latwizne i sciagali kod zanim nie poglowkuja jak go samemu napisac.
Go to the top of the page
+Quote Post
5z474n
post 4.05.2003, 22:27:39
Post #15





Grupa: Zarejestrowani
Postów: 51
Pomógł: 0
Dołączył: 2.05.2003

Ostrzeżenie: (0%)
-----


dobra spece .... bramka zawsze cos ale sa lepsze rzeczy smile.gif

ale zanim sie narobei musze wiedziec ze moj plan wypali smile.gif

chcialbym wiedziec:
:arrow: ile trfa polaczene isie z serwerem zalogowanie, wyslanei wiadomosci i zamkniecie polaczenia questionmark.gif :]
:arrow: czy sie da przez php logowac nowych userow i jak to zrobic ? smile.gif
:arrow: czy mozna naraz zalogowac sie na pare kont ? i jak to wplynei na czas wykonania zapytania ? ( tak zeby wyszukiwarka nei zglaszala bledu bo strona sie nei wladuje przez jakistam czas )
:arrow: na jakie problemy zwiazane z tematem moge trafic ? ;]

heh.... z gory dzieki ! ( piszcie wszystko co wiecie, przyda sie kazda informacja ) ( tylk nie mowcie ze odpowiedzi znajduja sie wyzej )


--------------------
niczym ten co go nie ma //...........
Go to the top of the page
+Quote Post
Seth
post 5.05.2003, 17:05:58
Post #16





Grupa: Przyjaciele php.pl
Postów: 2 335
Pomógł: 6
Dołączył: 7.03.2002

Ostrzeżenie: (0%)
-----


Ad.1
:arrow: Zalogowanie do servera: 0.213155984879 s.
(ustawiaijac sztywno wybrany IP i port hosta)
:arrow: Zalogowanie do servera w przypadku bledu laczenia: 3.38346207142 s (moze byc wiecej)
Skrypt wymaga jeszcze poprawienia logowania, lecz na 90% wysle wiaodmosc.
:arrow: Wysylanie wiadomosci: 0.000111937522888 s. (~1000 znakow)
:arrow: Wylogowanie: 0.000216960906982 s.

Ad.2
Jezeli przez program sie da to i przez php takze. Jak to zrobic ? Musisz poszperac sniferem w jaki sposob wysylane sa dane i otrzymywane przez program gg. Nie wiem czy przypadkiem na http://dev.null.pl/ekg/docs.php nie ma protokolu tworzenia usera (sprawdz).

Ad.3
Tak mozna. Czas bedzie taki jak suma poszczegolnych logowan, wysylania wiadomosci i wylogowania sie na poszczegolne konta. Aby nie bylo bledow wylacz zawieszenie skryptu po okreslonym czasie.

Ad.4
W przypadku gdy bedzie wiele polaczen moze sie zapchac lacze i spowolnic wysylanie (glownie logowanie) do serwera. W ekstremalnych przypadkach moze spowodowac zawieszenie serwera.
Go to the top of the page
+Quote Post
5z474n
post 5.05.2003, 18:20:46
Post #17





Grupa: Zarejestrowani
Postów: 51
Pomógł: 0
Dołączył: 2.05.2003

Ostrzeżenie: (0%)
-----


wieeelkie dzieki ... oczywiscie ze na tej strone ito jest smile.gif czasy tez mnei bardzo ciesza ....... wielkie dzieki !


--------------------
niczym ten co go nie ma //...........
Go to the top of the page
+Quote Post
5z474n
post 9.05.2003, 01:02:00
Post #18





Grupa: Zarejestrowani
Postów: 51
Pomógł: 0
Dołączył: 2.05.2003

Ostrzeżenie: (0%)
-----


gdzie jest zdefiniowany nr i haslo bramki questionmark.gif

chce zeby bylo zdefioniowane poza klasa ? :] czy ktos moze powiedziec jak to zrobic ?


--------------------
niczym ten co go nie ma //...........
Go to the top of the page
+Quote Post
Seth
post 9.05.2003, 12:57:52
Post #19





Grupa: Przyjaciele php.pl
Postów: 2 335
Pomógł: 6
Dołączył: 7.03.2002

Ostrzeżenie: (0%)
-----


Cytat
 function gg_gate( $to='', $msg='', $from='' ){  
   $this->to          = $to;  
   $this->msg         = $msg;  
   $this->from        = $from;  
   $this->debug_mode  = 0;  
   $this->debug_log   = array();  
   $this->_inner_vars = array();  

   $this->_inner_vars['gate_uinpass']  = array( '12345' => 'xxx', '4335' => 'xxx' ); // uin i haslo konta
   $this->_inner_vars['sys_msg']       = array(); // nr osatniej wiadomosci systemowej  
 }


Wyrozniony tekst to miejsce gdzie podaje sie nr-y i hasla do kont.

Kod
$this->_inner_vars['gate_uinpass']  = array( '12345' => 'xxx', '4335' => 'xxx' );

Tworzy sie tablice z kontami, gdyz jak nie wejdziemy po 3-ch zlaogowaniach na jedno konto idziemy na drugie itd. - w zaleznosci ile podalismy kont.
Struktura podawania kont jest taka:
'<nr konta>' => '<haslo>'

Jezeli chcesz miec to poza klasa to skasuj wyrozniona wyzej linijke i poza nia ustaw np tak:
[php:1:250cfadd23]
(...)
$gg = new gg_gate();
(...)
$gg->_inner_vars['gate_uinpass'] = array( '<nr konta 1>' => '<haslo 1>', '<nr konta 2>' => '<haslo 2>' ); // uin i haslo konta [/php:1:250cfadd23]
Go to the top of the page
+Quote Post
5z474n
post 9.05.2003, 14:04:23
Post #20





Grupa: Zarejestrowani
Postów: 51
Pomógł: 0
Dołączył: 2.05.2003

Ostrzeżenie: (0%)
-----


hm.. troche inaczej to pzrerobilem ale cos skopalem bo
Kod
DEBUG> Pobieranie listy wiadomosci systemowych...

DEBUG> ...zakonczone

DEBUG> Logowanie na konto: [~]

DEBUG> Laczenie z hostem...

DEBUG> ...zakonczone sukcesem

DEBUG> Pobieranie IP i portu...  

DEBUG> ...blad danych [!]                //!!!!!!!!

DEBUG> Wybrano domyslnego hosta 217.17.41.89:8074 [*]

DEBUG> Laczenie z 217.17.41.89:8074...

DEBUG> ...nie mozna nawiazac polaczenia [!] .... itd

no wlasnei jakis blad ... :|

[php:1:7e9e998195]<?php
function gg_gate( $to='', $msg='', $from='' ,$pass='' ){
$this->pass = $pass;
$this->to = $to;
$this->msg = $msg;
$this->from = $from;
$this->debug_mode = 2;
$this->debug_log = array();
$this->_inner_vars = array();

$this->_inner_vars['sys_msg'] = array(); // nr osatniej wiadomosci systemowej
}
?>[/php:1:7e9e998195]

tam dalej pozmeinailem na $this -> pass i $this -> from i ne iamm pojecia co jest nie tak :|


--------------------
niczym ten co go nie ma //...........
Go to the top of the page
+Quote Post

4 Stron V   1 2 3 > » 
Reply to this topicStart new topic
1 Użytkowników czyta ten temat (1 Gości i 0 Anonimowych użytkowników)
0 Zarejestrowanych:

 



RSS Wersja Lo-Fi Aktualny czas: 28.03.2024 - 17:06