찾다
백엔드 개발PHP 튜토리얼Google PR查询接口checksum新算法_php实例

前些日子一篇N久之前的老文忽然成了被阅读的热点,检查之后才发现自己使用那段代码来做pr查询的页面已经不能正常得到URL的Page Rank值了

取而代之的是一大段“In your email, please send us the entire code displayed below”之类的Google terms_of_service错误提示信息。看来是原先的接口已经失效了。

但我装在Firefox工具栏的扩展插件SearchStatus仍然能够正常解析出每个受访页的PR值,找到 SearchStatus 的插件包解开来看源码,果然是使用了不一样的验证码生成算法,在原先的 checksum 生成之后,还需要再进行一次计算,两次演算之后得到的才是正确的ch参数。

于是拿现成的js代码改造一番之后,新的PHP版本的 Google PageRank 查询接口方法就出来了。经过本地测试之后,谁想传到服务器之后又出现了该死的 terms_of_service 错误提示。把checksum的计算过程一步步打出来,发现经过了几次右位移之后本地和服务器上的数字就不一样了。这才想到服务器是64位机,32位系统下位移之后应该被cut掉的bit在那里就活得好好的。加了个 trunkbitForce32bit 方法,对所有算术运算之后的数值进行高位屏蔽,算是搞定了64位系统下的多余位问题。结果拿到32位Linux环境下跑又不兼容了,原因是PHP在进行算术处理出现溢出时,会自动尝试将int转为float。当发生的是负数溢出时,这一操作在Windows下能正确保留精度,但在Linux下就有问题了。

下面这段代码:

$a = -4294967295;
echo dechex($a)."df250b2156c434f3390392d09b1c9563\n";
if ( $a < 0 ) $a += 4294967296;
echo dechex($a)."df250b2156c434f3390392d09b1c9563\n";

第一个echo在Windows下能够正确输出该负数低32位的补码,而在32位Linux机上输出的则是int类型所能表示的最大负数0x80000000了。只有通过取巧的方式给这个溢出的大负数加上一个超出整数范围的大整数来抵消掉溢出的部分,才能复原低32位应该有的样子。

使用这些非常规手段,终于炮制出这个更新版的兼容Linux32/Linux64/Windows的Google PR值查询接口的PHP脚本实现(含完整代码)。


Google本身提供了查询指定的url的PageRank值的接口,知道了这个接口,就可以很容易编写脚本在页面上实现这一功能,而无需再依赖google toolbar才能进行查询。本文提供了一个用PHP实现的pr查询接口。同时修正了大部分版本中存在的 Linux 操作系统及64位操作系统下无法正常生成checksum的问题。


使用很简单,只要在需要的地方

fa7dc1d850e835711a146b717700644c

即可显示出指定url的PageRank的数值。知道了这个数值再在其基础上模拟出Google Toolbar上面的图形化的pr显示也就不是难事了。实际上实现原理说白了也很简单,就是传递特定的查询参数到Google的搜索引擎,然后抓取返回的页面内容。

演示页面请参见 : Google PageRank Query

本文代码素材来源: http://www.php.cn/ ;NewGCH方法实现参考于Firefox的工具栏扩展插件SearchStatus的相关代码实现。

网上还有一个开源的pr状态查询的项目: http://www.php.cn/ , 可以从cvs上直接抓取完整的源代码(cvs用户密码 guest):

cvs -d :pserver:guest@mozdev.org:/cvs login
cvs -d :pserver:guest@mozdev.org:/cvs co pagerankstatus

一个专门提供pr显示接口的网站: http://www.php.cn/

------------------------------------------------------------------

pr.inc.php源文件如下(Updated 2008-05-04 14:29 -- Google修改了checksum的计算算法,需要在原有的GCH方法之后再套一层NewGCH方法来得到正确的checksum,同时引发的php int overflow及64位机器兼容性问题请参照以下源代码的变化部分):

<?php 
// url get method macro. 
define(&#39;G_PR_GET_TYPE_FILE&#39;, 1); // use fopen() function 
define(&#39;G_PR_GET_TYPE_SOCKET&#39;, 2); // use standard fsocketopen function 
// main function to be called 
function getPR($_url,$gettype=G_PR_GET_TYPE_SOCKET){ 
$url = &#39;info:&#39;.$_url; 
$ch = GCH(strord($url)); 
$ch = NewGCH($ch); 
$url=str_replace("_","%5F",&#39;info:&#39;.urlencode($_url)); 
$googlePRUrl = 
"http://toolbarqueries.google.com/search?client=navclient-auto&ch=6" 
.$ch."&ie=UTF-8&oe=UTF-8&features=Rank&q=".$url; 
$pr_str = retrieveURLContent($googlePRUrl,$gettype); 
return substr($pr_str,strrpos($pr_str, ":")+1); 
} 
//unsigned shift right 
function zeroFill($a, $b){ 
$z = hexdec(&#39;8&#39;.implode(&#39;&#39;,array_fill(0,PHP_INT_SIZE*2-1,&#39;0&#39;))); 
if ($z & $a){ 
$a = ($a>>1); 
$a &= (~$z); 
$a |= hexdec(&#39;4&#39;.implode(&#39;&#39;,array_fill(0,PHP_INT_SIZE*2-1,&#39;0&#39;))); 
$a = ($a>>($b-1)); 
} 
else{ 
$a = ($a>>$b); 
} 
return $a; 
} 
// discard bits beyonds 32 bit. 
function trunkbitForce32bit($n){ 
if(PHP_INT_SIZE <= 4){ 
settype($n,&#39;float&#39;); 
if ( $n < 0 ) $n += 4294967296; 
return $n; 
} 
else{ 
$clearbit = &#39;&#39;; 
for($i=0;$i<PHP_INT_SIZE-4;$i++){ 
$clearbit .= &#39;00&#39;; 
} 
for($i=0;$i<4;$i++){ 
$clearbit .= &#39;ff&#39;; 
} 
return ($n & hexdec($clearbit)); 
} 
} 
function bigxor($m,$n){ 
//if(function_exists(&#39;gmp_init&#39;)){ 
// return floatval(gmp_strval(gmp_xor($m,$n))); 
//} 
//else{ 
return $m ^ $n; 
//} 
} 
function mix($a,$b,$c){ 
$a = trunkbitForce32bit($a); 
$b = trunkbitForce32bit($b); 
$c = trunkbitForce32bit($c); 
$a -= $b; $a = trunkbitForce32bit($a); 
$a -= $c; $a = trunkbitForce32bit($a); 
$a = bigxor($a,(zeroFill($c,13))); $a = trunkbitForce32bit($a); 
$b -= $c; $b = trunkbitForce32bit($b); 
$b -= $a; $b = trunkbitForce32bit($b); 
$b = bigxor($b,trunkbitForce32bit($a<<8)); $b = trunkbitForce32bit($b); 
$c -= $a; $c = trunkbitForce32bit($c); 
$c -= $b; $c = trunkbitForce32bit($c); 
$c = bigxor($c,(zeroFill($b,13))); $c = trunkbitForce32bit($c); 
$a -= $b;$a = trunkbitForce32bit($a); 
$a -= $c;$a = trunkbitForce32bit($a); 
$a = bigxor($a,(zeroFill($c,12)));$a = trunkbitForce32bit($a); 
$b -= $c;$b = trunkbitForce32bit($b); 
$b -= $a;$b = trunkbitForce32bit($b); 
$b = bigxor($b,trunkbitForce32bit($a<<16)); 
$c -= $a; $c = trunkbitForce32bit($c); 
$c -= $b; $c = trunkbitForce32bit($c); 
$c = bigxor($c,(zeroFill($b,5))); $c = trunkbitForce32bit($c); 
$a -= $b;$a = trunkbitForce32bit($a); 
$a -= $c;$a = trunkbitForce32bit($a); 
$a = bigxor($a,(zeroFill($c,3)));$a = trunkbitForce32bit($a); 
$b -= $c;$b = trunkbitForce32bit($b); 
$b -= $a;$b = trunkbitForce32bit($b); 
$b = bigxor($b,trunkbitForce32bit($a<<10)); 
$c -= $a; $c = trunkbitForce32bit($c); 
$c -= $b; $c = trunkbitForce32bit($c); 
$c = bigxor($c,(zeroFill($b,15))); $c = trunkbitForce32bit($c); 
return array($a,$b,$c); 
} 
function NewGCH($ch){ 
$ch = ( trunkbitForce32bit( ( $ch / 7 ) << 2 ) | 
( ( myfmod( $ch,13 ) ) & 7 ) ); 
$prbuf = array(); 
$prbuf[0] = $ch; 
for( $i = 1; $i < 20; $i++ ) 
{ 
$prbuf[$i] = $prbuf[$i-1] - 9; 
} 
$ch = GCH( c32to8bit( $prbuf ) ); 
return $ch; 
} 
function myfmod($x,$y){ 
$i = floor( $x / $y ); 
return ( $x - $i * $y ); 
} 
function c32to8bit($arr32){ 
$arr8 = array(); 
for( $i = 0; $i < count($arr32); $i++ ) { 
for( $bitOrder = $i * 4; 
$bitOrder <= $i * 4 + 3; $bitOrder++ ) { 
$arr8[$bitOrder] = $arr32[$i] & 255; 
$arr32[$i] = zeroFill( $arr32[$i], 8 ); 
} 
} 
return $arr8; 
} 
function GCH($url, $length=null){ 
if(is_null($length)) { 
$length = sizeof($url); 
} 
$init = 0xE6359A60; 
$a = 0x9E3779B9; 
$b = 0x9E3779B9; 
$c = 0xE6359A60; 
$k = 0; 
$len = $length; 
$mixo = array(); 
while( $len >= 12 ){ 
$a += ($url[$k+0] +trunkbitForce32bit($url[$k+1]<<8) 
+trunkbitForce32bit($url[$k+2]<<16) 
+trunkbitForce32bit($url[$k+3]<<24)); 
$b += ($url[$k+4] +trunkbitForce32bit($url[$k+5]<<8) 
+trunkbitForce32bit($url[$k+6]<<16) 
+trunkbitForce32bit($url[$k+7]<<24)); 
$c += ($url[$k+8] +trunkbitForce32bit($url[$k+9]<<8) 
+trunkbitForce32bit($url[$k+10]<<16) 
+trunkbitForce32bit($url[$k+11]<<24)); 
$mixo = mix($a,$b,$c); 
$a = $mixo[0]; $b = $mixo[1]; $c = $mixo[2]; 
$k += 12; 
$len -= 12; 
} 
$c += $length; 
switch( $len ) { 
case 11: 
$c += trunkbitForce32bit($url[$k+10]<<24); 
case 10: 
$c+=trunkbitForce32bit($url[$k+9]<<16); 
case 9 : 
$c+=trunkbitForce32bit($url[$k+8]<<8); 
case 8 : 
$b+=trunkbitForce32bit($url[$k+7]<<24); 
case 7 : 
$b+=trunkbitForce32bit($url[$k+6]<<16); 
case 6 : 
$b+=trunkbitForce32bit($url[$k+5]<<8); 
case 5 : 
$b+=trunkbitForce32bit($url[$k+4]); 
case 4 : 
$a+=trunkbitForce32bit($url[$k+3]<<24); 
case 3 : 
$a+=trunkbitForce32bit($url[$k+2]<<16); 
case 2 : 
$a+=trunkbitForce32bit($url[$k+1]<<8); 
case 1 : 
$a+=trunkbitForce32bit($url[$k+0]); 
} 
$mixo = mix( $a, $b, $c ); 
$mixo[2] = trunkbitForce32bit($mixo[2]); 
if( $mixo[2] < 0 ){ 
return ( 
hexdec(&#39;1&#39;. 
implode(&#39;&#39;, 
array_fill(0,PHP_INT_SIZE*2,&#39;0&#39;))) 
+ $mixo[2] ); 
} 
else{ 
return $mixo[2]; 
} 
} 
// converts a string into an array of integers 
// containing the numeric value of the char 
function strord($string){ 
for($i=0;$i<strlen($string);$i++){ 
$result[$i] = ord($string{$i}); 
} 
return $result; 
} 
// return url page content or false if failed. 
function retrieveURLContent($url,$gettype){ 
switch($gettype){ 
case G_PR_GET_TYPE_FILE: 
return retrieveURLContentByFile($url); 
break; 
default: 
return retrieveURLContentBySocket($url); 
break; 
} 
} 
function retrieveURLContentByFile($url){ 
$fd = @fopen($url,"r"); 
if(!$fd){ 
return false; 
} 
$result = ""; 
while($buffer = fgets($fd, 4096)) { 
$result .= $buffer; 
} 
fclose($fd); 
return $result; 
} 
function retrieveURLContentBySocket($url, 
$host="", 
$port=80, 
$timeout=30){ 
if($host == ""){ 
if(!($pos = strpos($url,&#39;://&#39;))){ 
return false; 
} 
$host = substr( $url, 
$pos+3, 
strpos($url,&#39;/&#39;,$pos+3) - $pos - 3); 
$uri = substr($url,strpos($url,&#39;/&#39;,$pos+3)); 
} 
else{ 
$uri = $url; 
} 
$request = "GET ".$uri." HTTP/1.0\r\n" 
."Host: ".$host."\r\n" 
."Accept: */*\r\n" 
."User-Agent: ZealGet\r\n" 
."\r\n"; 
$sHnd = @fsockopen ($host, $port, $errno, $errstr, $timeout); 
if(!$sHnd){ 
return false; 
} 
@fputs ($sHnd, $request); 
// Get source 
$result = ""; 
while (!feof($sHnd)){ 
$result .= fgets($sHnd,4096); 
} 
fclose($sHnd); 
$headerend = strpos($result,"\r\n\r\n"); 
if (is_bool($headerend)) 
{ 
return $result; 
} 
else{ 
return substr($result,$headerend+4); 
} 
}
성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
如何在Google Sheet中为图例添加标签如何在Google Sheet中为图例添加标签Feb 19, 2024 am 11:03 AM

本文将演示如何在GoogleSheet中为图例添加标签,这些标签侧重于单个事物,提供名称或标识。图例解释了事物的系统或组,为您提供相关的上下文信息。如何在GoogleSheet中为图例添加标签有时候,在使用图表时,我们想要让图表更易于理解。通过添加恰当的标签和图例,可以实现这一目的。接下来,我们将介绍如何在Google表格中为图例添加标签,让您的数据更加清晰明了。创建图表编辑图例标签的文本我们开始吧。1]创建图表要标记图例,首先,我们必须创建一个图表:首先,在GoogleSheets的列或行中输

Google Pixel 9 and Pixel 9 Pro rumoured to gain Creative Assistant AI upon releaseGoogle Pixel 9 and Pixel 9 Pro rumoured to gain Creative Assistant AI upon releaseJun 22, 2024 am 10:50 AM

Currently, four new Pixel smartphones are anticipated to land this autumn. To recap, the series is rumoured to feature thePixel 9 and Pixel 9 Pro at launch. However, the Pixel 9 Pro will be a rival to the iPhone 16 Pro rather than a Pixel 8 Pro (curr

优化谷歌浏览器下载速度的技巧与方法优化谷歌浏览器下载速度的技巧与方法Dec 27, 2023 pm 03:42 PM

在现代社会中,网络已经成为我们获取信息、分享资源和进行日常活动的主要方式。其中,文件下载是我们经常需要进行的操作之一,无论是从个人电脑到移动设备,还是从互联网服务器到本地存储设备。然而,快速稳定的文件下载可能会受到许多因素的影响,包括网络连接速度、服务器响应时间、浏览器性能等。今天,我们将重点讨论如何通过优化谷歌浏览器来提高文件下载速度。谷歌浏览器无法启动更新检查的解决方法1、打开谷歌浏览器,在地址栏输入【Chrome://flags】后按回车,进入到Chrome的实验功能中。 2、在搜索栏中搜

Google AI announces Gemini 1.5 Pro and Gemma 2 for developersGoogle AI announces Gemini 1.5 Pro and Gemma 2 for developersJul 01, 2024 am 07:22 AM

Google AI has started to provide developers with access to extended context windows and cost-saving features, starting with the Gemini 1.5 Pro large language model (LLM). Previously available through a waitlist, the full 2 million token context windo

Google app beta APK teardown reveals new extensions coming to Gemini AI assistantGoogle app beta APK teardown reveals new extensions coming to Gemini AI assistantJul 30, 2024 pm 01:06 PM

Google's AI assistant, Gemini, is set to become even more capable, if the APK teardown of the latest update (v15.29.34.29 beta) is to be considered. The tech behemoth's new AI assistant could reportedly get several new extensions. These extensions wi

顺手训了一个史上超大ViT?Google升级视觉语言模型PaLI:支持100+种语言顺手训了一个史上超大ViT?Google升级视觉语言模型PaLI:支持100+种语言Apr 12, 2023 am 09:31 AM

近几年自然语言处理的进展很大程度上都来自于大规模语言模型,每次发布的新模型都将参数量、训练数据量推向新高,同时也会对现有基准排行进行一次屠榜!比如今年4月,Google发布5400亿参数的语言模型PaLM(Pathways Language Model)在语言和推理类的一系列测评中成功超越人类,尤其是在few-shot小样本学习场景下的优异性能,也让PaLM被认为是下一代语言模型的发展方向。同理,视觉语言模型其实也是大力出奇迹,可以通过提升模型的规模来提升性能。当然了,如果只是多任务的视觉语言模

悄无声息,Google已禁止Colab上的Deepfake项目悄无声息,Google已禁止Colab上的Deepfake项目Apr 08, 2023 pm 07:11 PM

有消息显示,Google已于近日悄悄禁止了其在 Colaboratory(Colab)服务上的深度伪造(Deepfake)项目,这代表以Deepfake为目的大规模利用平台资源的时代或已画上句号。众所周知,Colab是一个在线计算资源平台,允许研究人员直接通过浏览器运行Python代码,同时使用包括GPU在内的免费计算资源来支持自己的项目。正由于GPU的多核特性,Colab是类似Deepfake模型机器学习项目或执行数据分析理想选择。经过一定训练,人们将Deepfake技术用于在视频片段中交换面

如何在 Ubuntu 上安装 Google 字体 22.04 LTS如何在 Ubuntu 上安装 Google 字体 22.04 LTSFeb 19, 2024 pm 11:18 PM

使用Google字体能够显著增强数字内容的视觉吸引力。透过精心挑选的字体,您可以为信息设定特定的氛围,提升文本的易读性,为观众带来更具吸引力的阅读体验。通过GoogleFonts,您可以轻松地探索各种字体风格,找到与您的设计理念完美契合的字体。在Ubuntu上安装GoogleFonts22.04LTSJammyJellyfish在开始安装之前,请务必确保您的Ubuntu22.04系统是最新的。保持系统更新不仅可确保您拥有最新功能和安全补丁,还有助于避免新软件安装时可能出现的兼容性问题。sudoa

See all articles

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover

AI Clothes Remover

사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

AI Hentai Generator

AI Hentai Generator

AI Hentai를 무료로 생성하십시오.

뜨거운 도구

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

SecList

SecList

SecLists는 최고의 보안 테스터의 동반자입니다. 보안 평가 시 자주 사용되는 다양한 유형의 목록을 한 곳에 모아 놓은 것입니다. SecLists는 보안 테스터에게 필요할 수 있는 모든 목록을 편리하게 제공하여 보안 테스트를 더욱 효율적이고 생산적으로 만드는 데 도움이 됩니다. 목록 유형에는 사용자 이름, 비밀번호, URL, 퍼징 페이로드, 민감한 데이터 패턴, 웹 셸 등이 포함됩니다. 테스터는 이 저장소를 새로운 테스트 시스템으로 간단히 가져올 수 있으며 필요한 모든 유형의 목록에 액세스할 수 있습니다.

안전한 시험 브라우저

안전한 시험 브라우저

안전한 시험 브라우저는 온라인 시험을 안전하게 치르기 위한 보안 브라우저 환경입니다. 이 소프트웨어는 모든 컴퓨터를 안전한 워크스테이션으로 바꿔줍니다. 이는 모든 유틸리티에 대한 액세스를 제어하고 학생들이 승인되지 않은 리소스를 사용하는 것을 방지합니다.

에디트플러스 중국어 크랙 버전

에디트플러스 중국어 크랙 버전

작은 크기, 구문 강조, 코드 프롬프트 기능을 지원하지 않음

mPDF

mPDF

mPDF는 UTF-8로 인코딩된 HTML에서 PDF 파일을 생성할 수 있는 PHP 라이브러리입니다. 원저자인 Ian Back은 자신의 웹 사이트에서 "즉시" PDF 파일을 출력하고 다양한 언어를 처리하기 위해 mPDF를 작성했습니다. HTML2FPDF와 같은 원본 스크립트보다 유니코드 글꼴을 사용할 때 속도가 느리고 더 큰 파일을 생성하지만 CSS 스타일 등을 지원하고 많은 개선 사항이 있습니다. RTL(아랍어, 히브리어), CJK(중국어, 일본어, 한국어)를 포함한 거의 모든 언어를 지원합니다. 중첩된 블록 수준 요소(예: P, DIV)를 지원합니다.