ajax发布到php返回一个空数组

时间:2018-03-05 05:00:01

标签: php jquery ajax

我已经停留了一段时间,将一些数据从ajax传递给php。一切正常,直到我用php获取数据。什么都没有,只有一个空数组。我已经尝试了几种不同的方法来解决这个问题并且根本没有成功。对我来说,一个简单的任务似乎已成为一个主要问题

var canvas = document.getElementById("signature");
var ImgData = document.getElementById("Image").value = canvas.toDataURL('image/jpeg');

console.log(ImgData);

$.ajax({
  url: 'upload.php',
  type: 'POST',
  dataType : "text",
  contentType: "multipart/form-data; charset=UTF-8",
  data: {'Image' : ImgData},

  success: function(data) {
    console.log("sucessful send:");
    console.log(data);
  },
  error: function(d) {
    console.log('error');
    console.log(d);
    console.log(d.responseText);
  }
});

我的php我现在已经开始测试了

  print_r($_POST); 
  exit;
  img = $_POST['Image'];

因为我用php得到了一个未定义的索引错误。所以我将其设置为print_r()以查看控制台中发生了什么

控制台数据显示一切都很好,直到我抓住POSTed数据并输出它以查看其中的内容。数组总是没有价值。

""  ajaxsend.js:41:3

POST XHR http://example.com/upload.php [HTTP/1.1 200 OK 313ms]
sucessful send:  ajaxsend.js:57:11

Array
(
)

我也试过以不同的方式获取画布,如其他人建议的那样,如

var pngImage = new FormData();

pngImage.append('Image', $('#signature')[0].toDataURL('image/jpeg'));

    $.ajax({
      url: 'upload.php',
      type: 'POST',
      dataType : "text",
      contentType: "multipart/form-data; charset=UTF-8",
      data: {'Image': $('#signature')[0].toDataURL('image/jpeg')},

同样的结果发生了。它发送正常,但返回一个空数组到PHP。我还将contentType设置为各种不同的东西,看看这是否干扰了数据的接收方式。什么都没有帮助。我也使用github的签名板2.3.0作为画布

更新: 感谢@Phil和他的建议,我已将代码更改为

var canvas = document.getElementById("signature");
var ImgData = document.getElementById("Image").value canvas.toDataURL('image/jpeg');

console.log(ImgData);

$.ajax({
url: 'upload.php',
type: 'POST',
dataType : "text",
contentType: "application/x-www-form-urlencoded; charset=UTF-8",
data: {'Image' : ImgData},

success: function(data) {
console.log("sucessful send:");
console.log(data);
},
error: function(d) {
console.log('error');
console.log(d);
console.log(d.responseText);
}
});

ajax超时尝试发送但是在使用纯文本进行测试并更改

data: {"Image" : "Testing"},

它的发送就好了。我怀疑它与正在发送的图像有关。我没有正确地将画布传递给ajax,还是我做错了什么?

0 个答案:

没有答案