使用x-amf(Flash)请求标头发送POST请求

时间:2011-04-13 13:42:04

标签: php flash post curl flashvars

我正在尝试使用PHP重现从WireShark捕获的POST请求。此POST请求是由Flash(.swf)对象发送的,因此在配置标头时有点复杂。

最终没有打印出任何东西,所以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  

以下是PHP代码,其中info.txt由HEX编辑器制作,所有信息都正确(即50字节,WireShark捕获的确切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);

结果是空白页而不是来自服务器的响应。

1 个答案:

答案 0 :(得分:1)

示例解决方案:

// Get content of x-amf file (must read in binary mode)
$fileHandle = fopen("info.txt", "rb");
$postdata = stream_get_contents($fileHandle);
fclose($fileHandle);

// Get cookie for CURL
$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);

// Set headers for CURL (with cookie stored in $m)
$header = array(
            "POST /engine/ HTTP/1.1",
            "User-Agent: Mozilla/5.0 (X11; U; Linux i686; en-US; rv:1.9.0.10) Gecko/2009042523 Ubuntu/9.04 (jaunty) Firefox/3.0.10",
            "Accept: text/html,application/xhtml+xml,application/xml;q=0.9,*/*;q=0.8",
            "Accept-Language: de, en-gb;q=0.9, en;q=0.8",
            "Accept-Encoding: gzip",
            "Accept-Charset: ISO-8859-1,utf-8;q=0.7,*;q=0.7",
            "Cache-Control: no-cache",
            "Pragma: no-cache",
            "Connection: close",
            "Referer: http://abcdef.com/v2.swf",
            "Content-Type: application/x-amf",
            "Cookie: ".$m[1],
            "Host: abcdef.com",
            "Content-Length: 50",
);

// Set options for CURL
$options = array(
    CURLOPT_HTTPHEADER          => $header,
    CURLOPT_POST                => true,
    CURLOPT_POSTFIELDS          => $postdata,
    CURLOPT_FOLLOWLOCATION      =>true
);

// POST the CURL and enjoy the outcome :)
$ch      = curl_init("http://abcdef.com");
curl_setopt_array( $ch, $options );
$content = curl_exec( $ch );
$err     = curl_errno( $ch );
$errmsg  = curl_error( $ch );
$header  = curl_getinfo( $ch );
curl_close( $ch );