我希望使用jQuery和FormData通过ajax将图片上传到服务器。
我的jQuery代码如下:
var formData = new FormData("form")[0];
var fileName = $("#InputLogo")[0].files[0].name;
$.ajax ( {
url : 'upload.php',
type : 'POST',
data : { "data" : formData, "fileName" : fileName },
processData : false,
success : function(data) {
console.log(data);
alert(data);
}
});
当用户选择上传新文件时,将调用此代码。
我的服务器后端是 PHP,并且它会按照以下方式处理请求。
$data = $_POST['data'];
$fileName = $_POST['fileName'];
$fp = fopen('/img/'.$fileName, 'w');
fwrite($fp, $data);
fclose($fp);
$returnData = array("data" => $data);
print_r($_POST);
发出了POST请求,但$_POST为空。
我尝试过搜索解决方案,但没有找到确切的解决方法。
任何建议都将不胜感激。
编辑:以下是HTML表单
<form id=card-form" method="post" action="" >
<div class="form-group">
<label for="InputName">Name of the Company</label>
<input type="text" class="form-control" id="InputName" placeholder="Enter a name">
</div>
<div class="form-group">
<label for="InputEmail">Email</label>
<input type="email" class="form-control" id="InputEmail" placeholder="Enter email">
</div>
<div class="form-group">
<label for="InputLogo">Choose a company logo</label>
<input type="file" id="InputLogo" accept="image/*">
<p class="help-block">For good visibility, please limit the image to 200 x 200 px</p>
</div>
<button type="submit" class="btn btn-default">Submit</button>
</form>
processData
йЂ‰йЎ№зљ„дЅњз”Ё... - CBroeprocessData
不是问题所在。 - Pankaj Bhambhani