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

来源:岁月联盟 编辑:zhuzhu 时间:2006-12-07

文档版本

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

Implementation Scope:

本文档将说明PHP页面接收HTTP组件POST的数据问题。一般来说,POST过来的二进制数据流,只需要PHP用$HTTP_RAW_POST_DATA就可以接收。但是,我们遇到的情况却不是这样。 继续阅读之前,我们假设您熟悉以下知识:n         PHPn         MSXML2.ServerXMLHTTPn         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.2SystemWindows NT 5.1 build 2600Server APICGI关于使用这个全局变量的相关设置:DirectiveLocal ValueMaster Valuealways_populate_raw_post_data00 

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

无法用$HTTP_RAW_POST_DATA接收POST数据的PHP for Linux安装信息:PHP Version 4.3.2RC3System 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 关于使用这个全局变量的相关设置:DirectiveLocal ValueMaster Valuealways_populate_raw_post_dataOnOn  

更多信息

照理说,只要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明确的书面许可,不得出于任何目的、以任何形式或手段(电子的、机械的、影印、录制等等)复制、传播本文的任何部分,也不得将其存储或引入到检索中。