Javascript XMLHttpRequest POST到PHP
我在管理一个简单的XMLHttpRequest的答案时遇到了一些问题,这个简单的XMLHttpRequest是在我自己的服务器上JS上创建的。我有一些令人不安的答案,以下是我的代码: JavaScript:Javascript XMLHttpRequest POST到PHP,javascript,php,html,xmlhttprequest,request,Javascript,Php,Html,Xmlhttprequest,Request,我在管理一个简单的XMLHttpRequest的答案时遇到了一些问题,这个简单的XMLHttpRequest是在我自己的服务器上JS上创建的。我有一些令人不安的答案,以下是我的代码: JavaScript: function callPHP () { var xml = new XMLHttpRequest(); xml.open("POST", "http://localhost/ajaxTest", false); xml.setRequestHeader("Cont
function callPHP () {
var xml = new XMLHttpRequest();
xml.open("POST", "http://localhost/ajaxTest", false);
xml.setRequestHeader("Content-type", "application/x-www-form-urlencoded");
xml.send("format=json");
var resp = xml.responseText;
console.log(resp);
}
和PHP:
<?php
if (isset($_POST["format"])){
if($_POST["format"] == "json"){
echo '
{
"name": "Name",
"lastName": "LastName",
"dob" : "dd/mm/yyyy",
}
';
}
}else{
print_r($_POST);
echo "Error";
http_response_code(400);
}
?>
每当我执行JS时,我都会得到PHP代码的错误部分,甚至在请求时发送了“format=json”数据。但若我将asynchronous更改为true,我会得到一个get错误(在chrome的控制台中)400个错误请求,但并没有执行PHP的回显
我知道我必须检查xmlhttprequest状态和响应代码才能执行异步,我是直接在控制台上测试的
我不知道我做错了什么,POST数据应该独立于异步发送,对吗
谢谢大家! 看起来javascript函数的结构不正确。在发送请求之前,应该设置侦听器。在您的代码中,可能类似于:-
var xml = new XMLHttpRequest();
xml.onreadystatechange = function() {
if( xml.readyState==4 && xml.status==200 ){
console.log( xml.responseText );
}
};
xml.open("POST", "http://localhost/ajaxTest", false);
xml.setRequestHeader("Content-type", "application/x-www-form-urlencoded");
xml.send("format=json");
@developerwk他将false作为第三个参数传递给open函数,这意味着它是同步的。我明白你的意思,但是我更关心的是服务器端,为什么当我将asynchronous设置为true时会出现get错误?为什么没有执行回显“错误”。。。我确实试着直接在控制台上执行一个单独的JS,但是我得到了相同的答案您是否有一些重写规则来制定
http://localhost/ajaxTest
工作?如果没有。也许你只是缺少了.php
扩展。@developerwjk是的,你是对的,我只是需要在我的URL中添加index.html
,谢谢@developerwk您知道如何添加重写规则以避免将index.php
插入url吗?