我正在使用Javascript通过Ajax将表单数据发送到php进行验证和邮寄。我命名为formString的查询字符串看起来像此'name= John Smith'
。我只有一个输入字段,仅用于测试目的。我的客户端页面和服务器之间的Ajax通信很好,我使用下面显示的脚本成功检查了它。
问题是我无法在服务器端捕获formString查询。我在下面提供了用于捕获数据失败的方法。回声json_encode($name)
没有向HTML服务器返回任何内容。
我尝试使用序列化了多个输入字段值的查询,但不起作用。我尝试向查询字符串提交一个仅包含名字“ John”的简单字符串,但是它也不起作用。
processForm()
var name = document.getElementById("fullName").value;
var formString = name;
var name = document.getElementById("fullName").value;
var formString = name;
var xhr = new XMLHttpRequest();
xhr.open('POST', formfile.php, true);
xhr.setRequestHeader('Content-type', 'application/x-www-form-urlencoded');
xhr.setRequestHeader('X-Requested-With', 'XMLHttpRequest');
xhr.onreadystatechange = function () {
if(xhr.readyState == 4 && xhr.status == 200) {
var result = xhr.responseText;
xhr.send(formString);
button.addEventListener("click", function(event) {
event.preventDefault();
processForm();
PHP代码段:
header('Content-Type: application/json');
function is_ajax_request(){
return isset($_SERVER['HTTP_X_REQUESTED_WITH']) &&
$_SERVER['HTTP_X_REQUESTED_WITH'] == 'XMLHttpRequest';
}
if(is_ajax_request()) {
$Ajax_results = array (
'Testing Text' => 'Hello World',
'Your Ajax submittal succeeded.
);
echo json_encode($Ajax_results);
} else {
$None_Ajax_results = array (
'errors' => 'None Ajax - short'
'Your Ajax submittal failed. Errors.'
);
echo "Form is Non Ajax Submitted";
echo json_encode($None_Ajax_error);
exit;
}
定义并设置变量:
global $name;
$errors = null;
if (isset($_POST['name'])) { $name = $_POST['name']; }
else { $name = ''; }
echo '$name';
echo json_encode($name);
如果我正确地阅读了您的问题,并假设您在陈述的状态下在Ajax和服务器之间具有正确的心跳,请快速查看一下您的代码,前提是您未正确格式化“ formString”。为了使您的formString正确显示在$ _POST ['name']中,它应该是:
var formString = "name="+name
这是因为要发送的帖子字符串(在您的情况下为“ formString”)应采用以下格式:
field1=val1&field2=val2& ... fieldN=valN
其中注明了每个字段的名称,后跟'='和该字段的值。多个字段由'&'字符分隔。在PHP中将翻译为
$_POST = {field1=>val1, field2=>val2, ... fieldN=>valnN}
在服务器端。当然,这不是上面的文字代码,而是标准API的示例。仔细研究如何格式化HTML GET / POST的发布字符串格式>