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

文档版本



















版本

创建时间

创建人

备注

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);

#p#副标题#e#

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