2013-05-27 32 views
2

我有点难住下面,任何帮助表示赞赏。我已经删除错误检查什么错的这个例子代码...

我运行PHP 5.4.14和使用PHP的服务器...

编辑:感谢来自阿尔瓦罗帮助我现在可以看到问题是$HTTP_RAW_POST_DATA实际上碰到了PHP开发服务器,但由于某种原因,它并未用于填充$_POST

JavaScript片段(从实际代码采取这里simplfied)当我点击提交表单按钮是被称为...

xmlhttp = new XMLHttpRequest(); 

<snip> 
params = 
    "forename=" + encodeURIComponent(form.forename.value) + "&" + 
    "surname=" + encodeURIComponent(form.surname.value) + "&" + 
    "nonce=" + encodeURIComponent(form.nonce.value); 


<snip> 
xmlhttp.open("POST", url, false); 

<snip> 
if (xmlhttp.overrideMimeType) 
{ 
    xmlhttp.overrideMimeType('text/html'); 
} 
xmlhttp.setRequestHeader("Content-type", "application/x-www-form-urlencoded"); 
xmlhttp.setRequestHeader("Content-length", params.length); 
xmlhttp.setRequestHeader("Connection", "close"); 

alert(params); 
xmlhttp.send(params); 

alert我可以看到PARAMS都还好。

POST请求然后正确地命中我的脚本,但$_REQUEST数组(也是$_POST)的错误日志给了我一个空数组。我一进入脚本就会完成$_REQUEST/_POST的错误日志。

我的脚本回复和JavaScript可以拿起答复...但当然,我所有的脚本可以返回是错误代码... doh。

任何想法,为什么这可能是这种情况?编辑:感谢ÁlvaroG. Vicario为他的帮助迄今。现在我可以看到请求确​​实离开了浏览器。

Request URL:http://localhost:8000/php_database/search_member.php 
Request Method:POST 
Status Code:200 OK 
Request Headers 
    POST /php_database/search_member.php HTTP/1.1 
    Host: localhost:8000 
    Connection: keep-alive 
    Content-Length: 69 
    Origin: http://localhost:8000 
    User-Agent: Mozilla/5.0 (Windows NT 6.1; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/27.0.1453.94 Safari/537.36 
    Content-type: application/x-www-form-urlencoded 
    Accept: */* 
    Referer: http://localhost:8000/php_database/db_search.php 
    Accept-Encoding: gzip,deflate,sdch 
    Accept-Language: en-US,en;q=0.8 
    Cookie: PHPSESSID=954ebbfadb841ef659a3961a44d715871bdedbaa 
Form Data 
    forename=ss&surname=dd&nonce=6c3e75f500dffdbfefe95d91710432dd8fd23fab 
Response Headers 
    HTTP/1.1 200 OK 
    Host: localhost:8000 
    Connection: close 
    X-Powered-By: PHP/5.4.14 
    Expires: Thu, 19 Nov 1981 08:52:00 GMT 
    Cache-Control: no-store, no-cache, must-revalidate, post-check=0, pre-check=0 
    Pragma: no-cache 
    Content-type: text/xml 

的PHP脚本运行......剧本是前两行...

<?php 
    $DEBUG = TRUE; 
    if($DEBUG){ error_log("\n\n\n", 0); error_log("\n\n> SEARCH MEMBER SCRIPT", 0); } 
    error_log(print_r($_REQUEST, TRUE), 0); 

哪些日志输出...

> SEARCH MEMBER SCRIPT 
[Mon May 27 15:42:22 2013] Array 
(
) 

如果我再添打印$_POST,相同...

如果我按照...评论,只是让我的脚本打印出一些全球性.. 。

我得到以下

array(0) { 
} 
array(0) { 
} 
array(0) { 
} 
array(25) { 
    ["DOCUMENT_ROOT"]=> 
    string(7) "C:\TJJT" 
    ["REMOTE_ADDR"]=> 
    string(3) "::1" 
    ["REMOTE_PORT"]=> 
    string(5) "59543" 
    ["SERVER_SOFTWARE"]=> 
    string(29) "PHP 5.4.14 Development Server" 
    ["SERVER_PROTOCOL"]=> 
    string(8) "HTTP/1.1" 
    ["SERVER_NAME"]=> 
    string(9) "localhost" 
    ["SERVER_PORT"]=> 
    string(4) "8000" 
    ["REQUEST_URI"]=> 
    string(31) "/php_database/search_member.php" 
    ["REQUEST_METHOD"]=> 
    string(4) "POST" 
    ["SCRIPT_NAME"]=> 
    string(31) "/php_database/search_member.php" 
    ["SCRIPT_FILENAME"]=> 
    string(38) "C:\TJJT\php_database\search_member.php" 
    ["PHP_SELF"]=> 
    string(31) "/php_database/search_member.php" 
    ["HTTP_HOST"]=> 
    string(14) "localhost:8000" 
    ["HTTP_CONNECTION"]=> 
    string(10) "keep-alive" 
    ["HTTP_CONTENT_LENGTH"]=> 
    string(2) "75" 
    ["HTTP_ORIGIN"]=> 
    string(21) "http://localhost:8000" 
    ["HTTP_USER_AGENT"]=> 
    string(108) "Mozilla/5.0 (Windows NT 6.1; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/27.0.1453.94 Safari/537.36" 
    ["HTTP_CONTENT_TYPE"]=> 
    string(33) "application/x-www-form-urlencoded" 
    ["HTTP_ACCEPT"]=> 
    string(3) "*/*" 
    ["HTTP_REFERER"]=> 
    string(48) "http://localhost:8000/php_database/db_search.php" 
    ["HTTP_ACCEPT_ENCODING"]=> 
    string(17) "gzip,deflate,sdch" 
    ["HTTP_ACCEPT_LANGUAGE"]=> 
    string(14) "en-US,en;q=0.8" 
    ["HTTP_COOKIE"]=> 
    string(50) "PHPSESSID=b1e2eb2ba3d687bfeadee6bc17e1b994c214cd3a" 
    ["REQUEST_TIME_FLOAT"]=> 
    float(1369666751.2246) 
    ["REQUEST_TIME"]=> 
    int(1369666751) 
} 
string(75) "forename=xfvz&surname=zxcvzx&nonce=276083038fdd9a932ff06b94e5786fdd840873a4" 

在上面,我可以清楚地看到底部...

string(75) "forename=xfvz&surname=zxcvzx&nonce=276083038fdd9a932ff06b94e5786fdd840873a4" 

哇。所以$HTTP_RAW_POST_DATA实际上确实碰到了PHP开发服务器......但由于某种原因,它并不适用于填充$_POST

+0

这是我推荐的jQuery。让生活更轻松。 – itachi

+0

据我所知,代码中没有任何内在错误。错误必须位于您省略的部分。作为一般规则,'alert()'是一个糟糕的调试工具。使用Firebug或浏览器的等效工具检查变量和HTTP请求。 –

+0

@Alvaro:谢谢你的回复。是的同意'alert()'很笨拙!在'xmlhttp.send(params);'这行之后,这就是HTTP请求消失了吗?从Javascript方面来说,如果'params'没问题,任何东西都可能是错的?在PHP方面,你有任何关于如何调试的建议吗?我不知道如何调试,一旦由PHP服务器接收到的HTTP请求......是存在的,前例如,一个办法看到HTTP请求作为,如果与本地主机交谈时,我会wiresharked呢?谢谢:) – Jimbo

回答

1

您的客户端代码正在发送一个POST请求(显然)是预期数据作为请求主体,并且信息到达PHP。但是,信息结束于$HTTP_RAW_POST_DATA而不是$_POST

always_populate_raw_post_data directive的手册页解释了这个:

始终在$HTTP_RAW_POST_DATA包含原始POST 数据。 否则,变量仅与未识别 MIME类型的数据的填充。但是,访问 原始POST数据的首选方法是php://输入。 $ HTTP_RAW_POST_DATA不与ENCTYPE =“多部分/格式数据”可用 。

这提供了一个可能的解释:PHP未能识别Content-Type请求标头。

有在这个解释建议PHP的bug跟踪系统(POST values in Google Chrome XHR)的报告。原因可能是Google Chrome浏览器的功能与其他浏览器不同,而PHP的内置服务器无法处理它。我认为你应该遵循这一研究路线。

+0

正确的你是...相同的PHP代码和JavaScript通过IE浏览器运行...'$ _POST'正确填充。谢谢! – Jimbo

+0

我会回应上面的第一条(非特定的)建议:使用jQuery。在过去的几年里,我从来没有在任何浏览器中提交过Ajax请求的问题,仅仅为了Ajax就值得。 – Jason

相关问题