ホームページ  >  記事  >  バックエンド開発  >  Google PR値のPHP実装コード

Google PR値のPHP実装コード

WBOY
WBOYオリジナル
2016-07-25 08:57:491136ブラウズ
  1. //PageRank Lookup v1.1 by HM2K (更新日: 31/01/07)
  2. //ここにあるロゴに基づいています: http://pagerank.gamesaga.net/
  3. //設定 - ホストとユーザー エージェント
  4. $googlehost='toolbarqueries.google.com';
  5. $googleua='Mozilla/5.0 (Windows; U; Windows NT 5.1; en-US; rv:1.8.0.6) Gecko/20060728 Firefox/1.5';
  6. //文字串转换到32位整数
  7. function StrToNum($Str, $Check, $Magic) {
  8. $Int32Unit = 4294967296; // 2^32
  9. $length = strlen($Str);
  10. for ($i = 0; $i < $length; $i++) {
  11. $Check *= $Magic;
  12. //浮動小数点数が整数の境界を越える場合 (通常 +/- 2.15e+9 = 2^31)、
  13. // 整数への変換結果は未定義です
  14. // http://www.php を参照.net/manual/en/ language.types.integer.php
  15. if ($Check >= $Int32Unit) {
  16. $Check = ($Check - $Int32Unit * (int) ($Check / $Int32Unit));
  17. //チェックが -2^31
  18. 未満の場合 $Check = ($Check }
  19. $Check += ord($Str{$i});
  20. }
  21. return $Check;
  22. }
  23. //将URL进行哈希编码
  24. function HashURL($String) {
  25. $Check1 = StrToNum($String, 0x1505, 0x21);
  26. $Check2 = StrToNum($String, 0, 0x1003F);
  27. $Check1 >>= 2;
  28. $Check1 = (($Check1 >> 4) & 0x3FFFFC0 ) | ($Check1 & 0x3F);
  29. $Check1 = (($Check1 >> 4) & 0x3FFC00 ) | ($Check1 & 0x3FF);
  30. $Check1 = (($Check1 >> 4) & 0x3C000 ) | ($Check1 & 0x3FFF);
  31. $T1 = (((($Check1 & 0x3C0) << 4) | ($Check1 & 0x3C)) <<2 ) | ($Check2 & 0xF0F );
  32. $T2 = (((($Check1 & 0xFFFFC000) << 4) | ($Check1 & 0x3C00)) << 0xA) | ($Check2 & 0xF0F0000 );
  33. return ($T1 | $T2);
  34. }
  35. //為哈希字符串生成校验码
  36. function CheckHash($Hashnum) {
  37. $CheckByte = 0;
  38. $Flag = 0;
  39. $HashStr = sprintf('%u', $Hashnum) ;
  40. $length = strlen($HashStr);
  41. for ($i = $length - 1; $i >= 0; $i --) {
  42. $Re = $HashStr{$i};
  43. if (1 === ($Flag % 2)) {
  44. $Re += $Re;
  45. $Re = (int)($Re / 10) + ($Re % 10);
  46. }
  47. $CheckByte += $Re;
  48. $Flag ++;
  49. }
  50. $CheckByte %= 10;
  51. if (0 !== $CheckByte) {
  52. $CheckByte = 10 - $CheckByte;
  53. if (1 === ($Flag % 2) ) {
  54. if (1 = == ($CheckByte % 2)) {
  55. $CheckByte += 9;
  56. }
  57. $CheckByte >>= 1;
  58. }
  59. }
  60. return '7'.$CheckByte.$HashStr;
  61. }
  62. // 戻りpagerank哈希校验码
  63. function getch($url) { return CheckHash(HashURL($url)); }
  64. //戻りPR值
  65. function getpr($url) {
  66. global $googlehost,$googleua;
  67. $ch = getch($url);
  68. $fp = fsockopen($googlehost, 80, $errno, $errstr , 30);
  69. if ($fp) {
  70. $out = "GET /search?client=navclient-auto&ch=$ch&features=Rank&q=info:$url HTTP/1.1rn";
  71. //echo "
     $out
    n"; //デバッグのみ
  72. $out .= "ユーザーエージェント: $googleuarn";
  73. $out .= "ホスト: $googlehostrn";
  74. $out .= "接続: Closernrn";
  75. fwrite($fp, $out );
  76. //$pagerank = substr(fgets($fp, 128), 4); //デバッグのみ
  77. //echo $pagerank; //デバッグのみ
  78. while (!feof($fp)) {
  79. $data = fgets($fp, 128);
  80. //echo $data;
  81. $pos = strpos($data, "Rank_");
  82. if ($pos === false){} else{
  83. $pr=substr($data, $pos + 9);
  84. $pr=trim($pr);
  85. $pr=str_replace("n",'', $pr);
  86. return $pr;
  87. }
  88. }
  89. //else { echo "$errstr ($errno)
    n"; } //デバッグのみ
  90. fclose($fp);
  91. }
  92. }
  93. // ページランク生成图形
  94. function pagerank($url,$width=40,$method='style') {
  95. if (!preg_match(' /^(http://)?([^/]+)/i', $url)) { $url='http://'.$url; }
  96. $pr=getpr($url);
  97. $pagerank="PageRank: $pr/10";
  98. // (古い) 画像メソッド
  99. if ($method == 'image') {
  100. $prpos= $width*$pr/10;
  101. $prneg=$width-$prpos;
  102. $html=''.$pagerank.'';
  103. }
  104. //事前にスタイル設定されたメソッド
  105. if ($method == 'style') {
  106. $prpercent=100*$pr/10;
  107. $html='
    '.$html.'';
  108. return $out;
  109. }
  110. if (( !isset($_POST['url'])) && (!isset($_GET['url']))) { echo '
    '; }
  111. if (isset($_REQUEST['url'])) { echo pagerank($_REQUEST['url']); }
  112. ?>
复制代

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。