0

从客户端A,我想通过 javascript 创建一个文件并通过 Ajax 将其发送到 Django 服务器B以进行进一步处理。

A中的 javascript 代码如下所示。我使用 blob 创建一个没有真正上传的文件并通过 Ajax 发送它。

console.log("start sending binary data...");
var form = new FormData();
var blob = new Blob([bytesArray], {type: 'example/binary'});    
form.append('file_name', blob, 'test.bin');    

$.ajax({
   url: THIRD_SERVER + 'test_binary',
   type: 'POST',       
   data: form,
   processData: false,
   success: function(data){
      console.log('test_binary ' + JSON.stringify(data));
   }
});

但是,在 Django 服务器上,我得到的是这样的(当 i 时print request.POST),因此当我使用 Django FileUpload时,它返回了一个异常。

<QueryDict: {u' name': [u'"file_name"'], u'------WebKitFormBoundarybCp3z7mAduz8BBDq\r\nContent-Disposition: form-data': [u''], u' filename': [u'"test.bin"\r\nContent-Type: example/binary\r\n\r\n\ufffd\ufffd\ufffd\x01\x05\x06\r\n------WebKitFormBoundarybCp3z7mAduz8BBDq--\r\n']}>

所以我猜上面的 javascript 没有做正确的事情来将文件发送到 Django 服务器。有什么合适的方法可以使用 FileUpload 来处理吗?

谢谢,

4

1 回答 1

1

您必须告诉 $.ajax 不要设置内容类型,否则会设置错误

$.ajax({
   url: THIRD_SERVER + 'test_binary',
   type: 'POST',       
   data: form,
   processData: false,
   contentType: false,
   success: function(data){
      console.log('test_binary ' + JSON.stringify(data));
   }
});
于 2014-07-05T03:53:50.387 回答