Mar 19 19 marzo
Calculate Google Pagerank with PHP Calcolare pagerank di Google con PHP
Posted by Thanadon March 19, 2007 at 9:10 pm 1 views Inviato da Thanadon 19 marzo 2007 a 9:10 pm 1 opinioni
Filed under: Internet , PHP , Programming Archiviato in: Internet, PHP, Programmazione
This is modified code that I found from the Internet the orginal code that may not work on some server that php has 32bit operation problem and I already tested on my server. Questo è modificato il codice che ho trovato da Internet il codice originale che potrebbe non funzionare su alcuni server che ha php 32bit operazione problema e ho già provato sul mio server.
PHP: PHP:
- <?php <? php
- define ( 'GOOGLE_MAGIC' , 0xE6359A60 ) ; define ( 'GOOGLE_MAGIC', 0xE6359A60);
- //unsigned shift right / / unsigned sposta a destra
- function zeroFill ( $a , $b ) zeroFill funzione ($ a, $ b)
- { (
- if ( $z & $a ) if ($ z & $ a)
- { (
- $a = ( $a >> 1 ) ; $ a = ($ a>> 1);
- $a &= ( ~ $z ) ; $ a & = (~ $ z);
- $a |= 0x40000000; $ a | = 0x40000000;
- $a = ( $a >> ( $b - 1 ) ) ; $ a = ($ a>> ($ b - 1));
- } )
- else altro
- { (
- $a = ( $a >> $b ) ; $ a = ($ a>> $ b);
- } )
- return $a ; return $ a;
- } )
- function toInt32 ( & $x ) { funzione toInt32 & ($ x) (
- $y = ( int ) $x ; $ y = (int) $ x;
- if ( $y ==- $z && $x <- $z ) { if ($ y $ z ==- & & $ x <- $ z) (
- $y = ( int ) ( ( - 1 ) * $x ) ; $ y = (int) ((- 1) * $ x);
- $y = ( - 1 ) * $y ; $ y = (- 1) * $ y;
- } )
- $x = $y ; $ $ x = y;
- } )
- function mix ( $a , $b , $c ) { funzione mix ($ a, $ b, $ c) (
- $a -= $b ; $a -= $c ; toInt32 ( $a ) ; $a = ( int ) ( $a ^ ( zeroFill ( $c , 13 ) ) ) ; $ a -= $ b, $ a -= $ c; toInt32 ($ a); $ a = (int) ($ a ^ (zeroFill ($ c, 13)));
- $b -= $c ; $b -= $a ; toInt32 ( $b ) ; $b = ( int ) ( $b ^ ( $a << 8 ) ) ; -= $ b $ c, $ b $ a -=; toInt32 ($ b); $ b = (int) ($ b ^ ($ a <<8));
- $c -= $a ; $c -= $b ; toInt32 ( $c ) ; $c = ( int ) ( $c ^ ( zeroFill ( $b , 13 ) ) ) ; -= $ c $ a; -= $ c $ b; toInt32 ($ c); $ c = (int) ($ c ^ (zeroFill ($ b, 13)));
- $a -= $b ; $a -= $c ; toInt32 ( $a ) ; $a = ( int ) ( $a ^ ( zeroFill ( $c , 12 ) ) ) ; $ a -= $ b, $ a -= $ c; toInt32 ($ a); $ a = (int) ($ a ^ (zeroFill ($ c, 12)));
- $b -= $c ; $b -= $a ; toInt32 ( $b ) ; $b = ( int ) ( $b ^ ( $a << 16 ) ) ; -= $ b $ c, $ b $ a -=; toInt32 ($ b); $ b = (int) ($ b ^ ($ a <<16));
- $c -= $a ; $c -= $b ; toInt32 ( $c ) ; $c = ( int ) ( $c ^ ( zeroFill ( $b , 5 ) ) ) ; -= $ c $ a; -= $ c $ b; toInt32 ($ c); $ c = (int) ($ c ^ (zeroFill ($ b, 5)));
- $a -= $b ; $a -= $c ; toInt32 ( $a ) ; $a = ( int ) ( $a ^ ( zeroFill ( $c , 3 ) ) ) ; $ a -= $ b, $ a -= $ c; toInt32 ($ a); $ a = (int) ($ a ^ (zeroFill ($ c, 3)));
- $b -= $c ; $b -= $a ; toInt32 ( $b ) ; $b = ( int ) ( $b ^ ( $a << 10 ) ) ; -= $ b $ c, $ b $ a -=; toInt32 ($ b); $ b = (int) ($ b ^ ($ a <<10));
- $c -= $a ; $c -= $b ; toInt32 ( $c ) ; $c = ( int ) ( $c ^ ( zeroFill ( $b , 15 ) ) ) ; -= $ c $ a; -= $ c $ b; toInt32 ($ c); $ c = (int) ($ c ^ (zeroFill ($ b, 15)));
- } )
- function GoogleCH ( $url , $length = null , $init =GOOGLE_MAGIC ) { funzione GoogleCH ($ url, $ lunghezza = null, $ init = GOOGLE_MAGIC) (
- } )
- $a = $b = 0x9E3779B9; $ a = $ b = 0x9E3779B9;
- $c = $init ; $ c = $ init;
- $k = 0 ; $ k = 0;
- $len = $length ; $ len = $ lunghezza;
- while ( $len >= 12 ) { while ($ len> = 12) (
- $a += ( $url [ $k + 0 ] + ( $url [ $k + 1 ] << 8 ) + ( $url [ $k + 2 ] << 16 ) + ( $url [ $k + 3 ] << 24 ) ) ; $ a + = ($ url [$ k + 0] + ($ url [$ k + 1] <<8) + ($ url [$ k + 2] <<16) + ($ url [$ k + 3] <<24));
- $b += ( $url [ $k + 4 ] + ( $url [ $k + 5 ] << 8 ) + ( $url [ $k + 6 ] << 16 ) + ( $url [ $k + 7 ] << 24 ) ) ; $ b + = ($ url [$ k + 4] + ($ url [$ k + 5] <<8) + ($ url [$ k + 6] <<16) + ($ url [$ k + 7] <<24));
- $c += ( $url [ $k + 8 ] + ( $url [ $k + 9 ] << 8 ) + ( $url [ $k + 10 ] << 16 ) + ( $url [ $k + 11 ] << 24 ) ) ; $ c + = ($ url [$ k + 8] + ($ url [$ k + 9] <<8) + ($ url [$ k + 10] <<16) + ($ url [$ k + 11] <<24));
- $mix = mix ( $a , $b , $c ) ; $ mix = mix ($ a, $ b, $ c);
- $a = $mix [ 0 ] ; $b = $mix [ 1 ] ; $c = $mix [ 2 ] ; $ a = $ mix [0]; $ b = $ mix [1]; $ c = $ mix [2];
- $k += 12 ; $ k + = 12;
- $len -= 12 ; $ len -= 12;
- } )
- $c += $length ; $ c + = $ lunghezza;
- switch ( $len ) /* all the case statements fall through */ switch ($ len) / * caso tutte le dichiarazioni caduta attraverso * /
- { (
- case 11 : $c += ( $url [ $k + 10 ] << 24 ) ; caso 11: $ c + = ($ url [$ k + 10] <<24);
- case 10 : $c += ( $url [ $k + 9 ] << 16 ) ; caso 10: $ c + = ($ url [$ k + 9] <<16);
- case 9 : $c += ( $url [ $k + 8 ] << 8 ) ; caso 9: $ c + = ($ url [$ k + 8] <<8);
- /* the first byte of c is reserved for the length */ / * Il primo byte di c è riservato per la lunghezza * /
- case 8 : $b += ( $url [ $k + 7 ] << 24 ) ; caso 8: $ b + = ($ url [$ k + 7] <<24);
- case 7 : $b += ( $url [ $k + 6 ] << 16 ) ; caso 7: $ b + = ($ url [$ k + 6] <<16);
- case 6 : $b += ( $url [ $k + 5 ] << 8 ) ; caso 6: $ b + = ($ url [$ k + 5] <<8);
- case 5 : $b += ( $url [ $k + 4 ] ) ; caso 5: $ b + = ($ url [$ k + 4]);
- case 4 : $a += ( $url [ $k + 3 ] << 24 ) ; case 4: $ a + = ($ url [$ k + 3] <<24);
- case 3 : $a += ( $url [ $k + 2 ] << 16 ) ; case 3: $ a + = ($ url [$ k + 2] <<16);
- case 2 : $a += ( $url [ $k + 1 ] << 8 ) ; case 2: $ a + = ($ url [$ k + 1] <<8);
- case 1 : $a += ( $url [ $k + 0 ] ) ; case 1: $ a + = ($ url [$ k + 0]);
- /* case 0: nothing left to add */ / * Caso 0: niente da aggiungere * /
- } )
- $mix = mix ( $a , $b , $c ) ; $ mix = mix ($ a, $ b, $ c);
- /*-------------------------------------------- report the result */ /*-------------------------------------------- Relazione il risultato * /
- return $mix [ 2 ] ; return $ mix [2];
- } )
- //converts a string into an array of integers containing the numeric value of the char / / converte una stringa in una matrice di interi contenente il valore numerico del carattere
- function strord ( $string ) { funzione strord ($ string) (
- for ( $i = 0 ; $i <strlen ( $string ) ; $i ++ ) { for ($ i = 0; $ i <strlen ($ string); $ i + +) (
- } )
- return $result ; return $ result;
- } )
- // converts an array of 32 bit integers into an array with 8 bit values. / / Converte un array di interi a 32 bit in una serie con valori a 8 bit. Equivalent to (BYTE *)arr32 Equivalenti a (BYTE *) arr32
- function c32to8bit ( $arr32 ) { funzione c32to8bit ($ arr32) (
- for ( $i = 0 ; $i <count ( $arr32 ) ; $i ++ ) { for ($ i = 0; $ i <count ($ arr32); $ i + +) (
- for ( $bitOrder = $i * 4 ; $bitOrder <= $i * 4 + 3 ; $bitOrder ++ ) { for ($ bitOrder = $ i * 4; $ bitOrder <= $ i + 4 * 3; $ bitOrder + +) (
- $arr8 [ $bitOrder ] = $arr32 [ $i ] & 255 ; arr8 $ [$ bitOrder] = $ arr32 [$ i] & 255;
- $arr32 [ $i ] =zeroFill ( $arr32 [ $i ] , 8 ) ; arr32 $ [$ i] = zeroFill ($ arr32 [$ i], 8);
- } )
- } )
- return $arr8 ; return $ arr8;
- } )
- function get_page_rank ( $url ) { funzione get_page_rank ($ url) (
- $url = preg_replace ( '/ \? .*$/' , '?' , $url ) ; $ url = preg_replace ( '/ \? .*$/','? ', $ url);
- $reqgr = "info:" . $url ; reqgr $ = "info:". $ url;
- $gch = "6" .GoogleCH ( strord ( $reqgr ) ) ; gch $ = "6". GoogleCH (strord ($ reqgr));
- if ( ! $fsock ) { if (! $ fsock) (
- echo 'Can not connect to server' ; echo 'Impossibile connettersi al server';
- return - 1 ; ritorno - 1;
- } )
- $base_get = "/search?client=navclient-auto&ch=" . $gch . "&ie=UTF-8&oe=UTF-8&features=Rank:FVN&q=" . $reqgre ; base_get $ = "/ search? cliente = navclient-auto & ch =". gch $. "& ie = UTF-8 & oe = UTF-8 & caratteristiche = Rank: FVN & q =". reqgre $;
- fputs ( $fsock , "HOST: toolbarqueries.google.com \r \n " ) ; fputs ($ fsock, "HOST: toolbarqueries.google.com \ r \ n");
- } )
- if ( preg_match ( '/Rank_.*?:.*?:( \d +)/i' , $res [ 'content' ] , $m ) ) { if (preg_match ( '/ Rank_ .*?:.*?:( \ d +) / i', $ res [ 'contenuto'], $ m)) (
- return $m [ 1 ] ; return $ m [1];
- } else {