0
我试图重现使用PHP从WireShark捕获的POST请求。这个POST请求是由Flash(.swf)对象发送的,所以在配置标题时有点复杂。使用x-amf(Flash)请求标头发送POST请求
它最终没有打印出任何东西,所以一定会出现我看不到的PHP代码错误。
这里是Wireshark的捕获:
POST /engine/ HTTP/1.1\r\n
Host: abcdef.com\r\n
User-Agent: Mozilla/5.0 (X11; Linux i686; rv:2.0) Gecko/20100101 Firefox/4.0\r\n
Accept: text/html,application/xhtml+xml,application/xml;q=0.9,*/*;q=0.8\r\n
Accept-Language: en-us,en;q=0.5\r\n
Accept-Encoding: gzip, deflate\r\n
Accept-Charset: UTF-8,*\r\n
Keep-Alive: 115\r\n
Connection: keep-alive\r\n
Cookie: __utma=77520967.190998754.1302600802.1302605710.1302693085.3; __utmz=77520967.1302600802.1.1.utmccn=(direct)|utmcsr=(direct)|utmcmd=(none); PHPSESSID=vqtt7v2l5h10nd06fdsuii49e0; __utmc=77520967
Referer: http://abcdef.com/v2.swf\r\n\r\n
Referer: http://abcdef.com/v2.swf\r\n
Content-Type: application/x-amf\r\n
Content-Length: 50\r\n
\r\n
这里是Wireshark的捕获的PHP代码与info.txt用十六进制编辑器和所有的信息做出正确(即50个字节,确切的HEX内容)
// Get cookie
$ch = curl_init('http://abcdef.com/');
curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);
curl_setopt($ch, CURLOPT_HEADER, 1);
preg_match('/^Set-Cookie: (.*?);/m', curl_exec($ch), $m);
// Read x-amf data
$fileHandle = fopen("info.txt", "rb");
$postdata = stream_get_contents($fileHandle);
fclose($fileHandle);
// Send POST request to server
$opts = array('http' =>
array(
'method' => 'POST',
'header' => "
User-Agent: Mozilla/5.0 (X11; Linux i686; rv:2.0) Gecko/20100101 Firefox/4.0\r\n
Accept: text/html,application/xhtml+xml,application/xml;q=0.9,*/*;q=0.8\r\n
Accept-Language: en-us,en;q=0.5\r\n
Accept-Encoding: gzip, deflate\r\n
Accept-Charset: UTF-8,*\r\n
Keep-Alive: 115\r\n
Cookie: ".$m[1]."\r\n
Connection: keep-alive\r\n
Referer: http://abcdef.com/v2.swf\r\n
Content-Type: application/x-amf\r\n
Content-Length: 50\r\n",
'content' => $postdata
)
);
$context = stream_context_create($opts);
$result = file_get_contents('http://abcdef.com/engine/', false, $context);
print_r($result);
结果是空白页而不是来自服务器的响应。
哪来的饼干吗? – trickwallett 2011-04-13 13:45:35
哦...我认为cookie虽然不是必要的,但是我只是添加了“Cookie:__utma = 77520967.190998754.1302600802.1302605710.130269308 ....”,并且空白空间的结果仍然相同,没有响应 – markbse 2011-04-13 13:48:26
给定了PHP会话cookie在那里,在猜测你必须获得一个有效的会话ID .. – trickwallett 2011-04-13 13:51:04