0

我正在用 PHP 编写一个 MSN 客户端。这是我到目前为止的代码:

$socket = fsockopen("messenger.hotmail.com", 1863);
echo '<b>Connected to 1st server.</b><br />';
//Send MSNP version
fputs($socket, "VER 0 MSNP10 CVR0\r\n");
echo fread($socket, 5000) . '<br />';
//Send user-agent
fputs($socket, "CVR 1 0x0409 php ".phpversion()." i386 MSNMSGR 7.0.0000 MSMSGS ".$_POST["username"]."\r\n");
echo fread($socket, 5000) . '<br />';
//Send username
fputs($socket, "USR 2 TWN I ".$_POST["username"]."\r\n");
//Read XFR
$xfr = fread($socket, 5000);
echo $xfr . '<br />';
$xfr = explode(" ", $xfr);

//Connect to second server
$server2 = explode(":", $xfr[3]);
$socket = fsockopen($server2[0], (int)$server2[1]);
echo '<b>Connected to 2nd server.</b><br />';
//Send MSNP version
fputs($socket, "VER 0 MSNP10 CVR0\r\n");
echo fread($socket, 5000) . '<br />';
//Send user-agent
fputs($socket, "CVR 1 0x0409 php ".phpversion()." i386 MSNMSGR 7.0.0000 MSMSGS ".$_POST["username"]."\r\n");
echo fread($socket, 5000) . '<br />';
//Send username
fputs($socket, "USR 2 TWN I ".$_POST["username"]."\r\n");
//Read USR
$usr = fread($socket, 5000);
echo $usr . '<br />';
$usr = explode(" ", $usr);

//Connect to Nexus
$nexus = fsockopen("nexus.passport.com", 443);
$request_nexus = "GET /rdr/pprdr.asp HTTP/1.1\r\n";
$request_nexus .= "Host:nexus.passport.com\r\n";
$request_nexus .= "User-Agent:MSNphp/1.0 (PHP; U; PHP 5; en-US)\r\n";
$request_nexus .= "Accept:text/html,application/xhtml+xml,application/xml;q=0.9,*/*;q=0.8\r\n";
$request_nexus .= "Accept-Language:en-us,en;q=0.5\r\n";
$request_nexus .= "Keep-Alive:300\r\n";
$request_nexus .= "Connection:keep-alive\r\n";
$request_nexus .= "Cache-Control:max-age=0\r\n\r\n";
fputs($nexus, $request_nexus);
echo fread($nexus, 5000);//This is line 54, which causes the error

我的结果是这样的:

连接到第一台服务器。
版本 0 MSNP10
CVR 1 1.0.0000 1.0.0000 1.0.0000 http://msgr.dlservice.microsoft.com http://download.live.com/?sku=messenger
XFR 2 NS 207.46.124.241:1863 0 65.54.239.21:1863
连接到第二台服务器。
版本 0 MSNP10
CVR 1 1.0.0000 1.0.0000 1.0.0000 http://msgr.dlservice.microsoft.com http://download.live.com/?sku=messenger
USR 2 TWN S ct=1249043921,rver=5.5.4177.0,wp=FS_40SEC_0_COMPACT,lc=1033,id=507,ru=http:%2F%2Fmessenger.msn.com,tw=0,kpp=1,kv=4 ,ver=2.1.6000.1,rn=1lgjBfIL,tpf=b0735e3a873dfb5e75054465196398e0

致命错误:第 54 行的 C:\wamp\apps\msnphp\chat.php 中超过了 30 秒的最大执行时间

连接到 Nexus 时出现超时错误。但是当我在 Firefox 中向https://nexus.passport.com/rdr/pprdr.asp发出请求时,我得到了我想要的结果(用 HttpFox 检查)。为什么 Nexus 需要花这么多时间来响应我的脚本?在 Firefox 中需要 2 秒。

有谁知道我做错了什么?

4

2 回答 2

5

当您连接到 nexus.passport.com 上的 SSL 端口 (443) 时,您实际上并没有发送加密的信息:因此 Nexus 只是在等待加密数据到达并最终超时(您的 PHP 脚本正在超时之前)。

您最好使用Curl将信息发送到 nexus,因为它能够为您处理 SSL 连接(为什么要重新发明轮子?)。

于 2009-07-31T12:57:49.013 回答
2

您的脚本运行时间很长。PHP 有一种机制,如果脚本运行的时间比设置中指定的时间长,它会终止脚本。您可以在您的脚本中更改此值(称为max_execution_time),php.ini也可以使用set_time_limit()函数在脚本中更改它。

于 2009-07-31T12:52:52.743 回答