php如何获取到formData上传图片的二进制数据
程序员文章站
2022-05-25 11:36:59
...
----------------------------------------------------------------
var fileInput = document.getElementById("file");
var file = fileInput.files[0];
var formData = new FormData();
formData.append("file", file);
$.ajax({
url: "./upload_photobank.php",
type: "POST",
data: formData,
processData: false, // 告诉jQuery不要去处理发送的数据
contentType: false, // 告诉jQuery不要去设置Content-Type请求头
complete : function(jqXHR, textStatus) {
if(jqXHR.status != 200){
console.log( 456 )
}else{
var jsonData = eval('(' + jqXHR.responseText + ')');
// var jsonData = jqXHR.responseText;
console.log(jqXHR.responseText);
}
}
});
php如何写 ,获取到上传的图片的二进制数据?
js部分是否有错误?
回复内容:
----------------------------------------------------------------
var fileInput = document.getElementById("file");
var file = fileInput.files[0];
var formData = new FormData();
formData.append("file", file);
$.ajax({
url: "./upload_photobank.php",
type: "POST",
data: formData,
processData: false, // 告诉jQuery不要去处理发送的数据
contentType: false, // 告诉jQuery不要去设置Content-Type请求头
complete : function(jqXHR, textStatus) {
if(jqXHR.status != 200){
console.log( 456 )
}else{
var jsonData = eval('(' + jqXHR.responseText + ')');
// var jsonData = jqXHR.responseText;
console.log(jqXHR.responseText);
}
}
});
php如何写 ,获取到上传的图片的二进制数据?
js部分是否有错误?
首先确保表单的属性要有enctype="multipart/form-data"
,实例化FormData不能为空啊!为空就获取不到表单值啊
用$_FILES,而不是$_POST
上传代码要写到input的“change”事件里……还有ajax的回调有点怪,都complate了就不要再判断status了吧。。
可以参考下我写的前端图片直传OSS试验
FormData
就是表单,所有数据的处理和表单是一样的,所以PHP也是一样的处理,上传文件仍然是通过$_FILES
来处理。