不同操作系统下PHP接收HTTP POST数据问题

发表于:2007-06-21来源:作者:点击数: 标签:
文档版本 版本 创建时间 创建人 备注 1.0.0606.1 2003-6-6 郑 昀 第一稿 Implementation Scope: 本文档将说明PHP页面接收HTTP组件POST的数据问题。一般来说,POST过来的二进制数据流,只需要PHP用$HTTP_RAW_POST_DATA就可以接收。但是,我们遇到的情况却不

   


  

文档版本

版本
创建时间
创建人
备注
1.0.0606.1
2003-6-6
郑           昀
第一稿
 
 
 
 

Implementation Scope:

本文档将说明PHP页面接收HTTP组件POST的数据问题。一般来说,POST过来的二进制数据流,只需要PHP用$HTTP_RAW_POST_DATA就可以接收。但是,我们遇到的情况却不是这样。
 
继续阅读之前,我们假设您熟悉以下知识
n         PHP
n         MSXML2.ServerXMLHTTP
n         HTTP POST
 

现象

我们遇到了这么一个问题:
我从Windows 2000上,利用MSXML2.ServerXMLHTTP接口向Linux Apche下的PHP页面POST二进制数据流。
PHP页面的$HTTP_RAW_POST_DATA变量为空,得不到数据,而且sizeof($_POST)的值也是0。
 
但是,如果我同样向一个Windows 2000 IIS下的PHP页面POST数据,却可以用$HTTP_RAW_POST_DATA接收到正常数据。
为什么二者有这种区别呢?

环境信息

发起HTTP POST请求方·系统环境

Windows XP Professional(Service Pack 1)
MSXML3.Dll(SP3 / 版本号:8.30.9926.0)
调用ServerXMLHTTP的代码是:
       MSXML2::IServerXMLHTTPRequestPtr pIXMLHttpRequest = NULL;
              HRESULT hr = pIXMLHttpRequest.CreateInstance("MSXML2.ServerXMLHTTP");
        hr = pIXMLHttpRequest->open(L"POST",
                                                               bstrPHPURL,
                                                               VARIANT_FALSE,  // 同步发送
                                                               vtMissing,
                                                               vtMissing);
        hr = pIXMLHttpRequest->send(varData);
 

正确接收POST请求的PHP for MS Windows·系统环境

用$HTTP_RAW_POST_DATA正常接收了数据的PHP for Windows安装信息:
PHP Version 4.2.2
System
Windows NT 5.1 build 2600
Server API
CGI
关于使用这个全局变量的相关设置:
Directive
Local Value
Master Value
always_populate_raw_post_data
0
0
 

无法接收POST请求的PHP for Linux·系统环境

无法用$HTTP_RAW_POST_DATA接收POST数据的PHP for Linux安装信息:
PHP Version 4.3.2RC3
System
Linux atm2 2.4.18-1 #1 Wed May 29 10:45:23 CST 2002 i686
Server API
Apache
Registered PHP Streams
php, http, ftp
关于使用这个全局变量的相关设置:
Directive
Local Value
Master Value
always_populate_raw_post_data
On
On
 
 

更多信息

照理说,只要php.ini中定义了
; Always populate the $HTTP_RAW_POST_DATA variable.
always_populate_raw_post_data = On
就完全可以用$HTTP_RAW_POST_DATA变量来接收数据。
起码$_POST变量是可以测算出POST到页面的数据大小的。
 
我确实看到有几个人试图报告“Empty $HTTP_RAW_POST_DATA”是一个PHP的Bug,但是PHP维护人员说肯定不是。

解决步骤

不知道Windows下的PHP 4.2.2怎么一直可以接收。
但是如果我显式声明Content-Type为file的话,Linux下的PHP 4.3.2RC3就可以正常接收POST数据了。
设置头信息的代码如下:
hr = pIXMLHttpRequest->setRequestHeader(
                                                               _bstr_t("Content-Type"),
                                                               _bstr_t("file"));
 
这样做的话,PHP 4.2.2 for Windows和PHP 4.3.2RC3 for Linux都可以用$HTTP_RAW_POST_DATA接收,没有问题。
 

总结:

如果你的$HTTP_RAW_POST_DATA不在那儿了,你可以在调用HTTP组件发送HTTP POST请求时,指定Content-Type为file。
 

Disclaimers:

本文档所包含的信息代表了在发布之日,zhengyun对所讨论问题的当前看法。本文档不应理解为zhengyun一方的承诺,zhengyun不保证所给信息在发布之日以后的准确性。
本文档仅供参考。
用户必须遵守所有适用的版权法。在不对版权法所规定的权利加以限制的情况下,如未得到 zhengyun和CSDN.Net明确的书面许可,不得出于任何目的、以任何形式或手段(电子的、机械的、影印、录制等等)复制、传播本文的任何部分,也不得将其存储或引入到检索系统中。

原文转自:http://www.ltesting.net