jQuery使用$ .post上传文件

时间:2016-05-12 17:09:42

标签: javascript php jquery

我需要通过jQuery将POST数据发送到我的PHP服务器。这就是我目前收到的内容(这就是我想要的):

client_id: 55
client_name: 'Josh'
age: '35'
extra: array(0) -> array(['preview'] -> true, ['lookup'] -> false)

为了达到这个目的,我有以下代码:

var elements    = [];
var listOfExtra = []

listOfExtra.push({'preview': true, 'lookup': false});

elements['client_id']   = 55;
elements['client_name'] = 'Josh';
elements['age']         = 35;
elements['extra']       = listOfExtra;

$.post(url, $.extend({}, elements));

但是现在我还需要发送用户上传的文件,所以这样做:

elements['file'] = event.target.files[0];

我在javascript

中收到消息Illegal invocation

由于这不起作用,我试图实现formData()

var formData = new FormData();

formData.append('client_id', 55);
formData.append('client_name', 'Josh');
formData.append('age', 35);
formData.append('extra', listOfExtra);
formData.append('file', event.target.files[0]);

$.ajax(
{
    url: url
    type: 'POST',
    data: formData,
    processData: false,
    contentType: false
});

现在extra[object][object],这是好的,所以我只需要对其进行字符串化。

formData.append('extra', JSON.stringify(listOfExtra));

现在的问题是我有很多使用$_POST['extra'][0]['preview']的代码(例如),现在我需要解码所有代码并使用很多条件,例如:

$extra = isset(json_decode($_POST['extra'])[0]['preview']);

if($extra != null)
   $extraContent = json_decode($_POST['extra'])[0];

$preview = (isset($extraContent) ? $extraContent->preview : $extra[$_POST['extra'][0]['preview']);

有没有办法使用formData()$.post我可以保存从javascript发送到我想要的PHP的值并发送文件?

2 个答案:

答案 0 :(得分:0)

一个简单的方法是,不要使用jQuery,只需

var xhr = new XMLHttpRequest();
xhr.send(formData);

它应该做所有正确的事情,但只适用于现代浏览器(不知道你是否也需要旧的浏览器)。有关兼容性,请查看http://caniuse.com/#feat=xhr2

答案 1 :(得分:0)

<强>解决

我将解码的JSON值再次转换为普通$_POST

$extraContent = json_decode($_POST['extra'])[0];

foreach($extraContent as $key => $extra)
   $_POST[$key] = $extra;