Maison >développement back-end >tutoriel php >php如何获取到formData上传图片的二进制数据
<code> <input id="file" type="file" accept="image/png,image/gif,image/jpeg" name="file"> ---------------------------------------------------------------- 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); } } });</code>
php如何写 ,获取到上传的图片的二进制数据?
js部分是否有错误?
<code> <input id="file" type="file" accept="image/png,image/gif,image/jpeg" name="file"> ---------------------------------------------------------------- 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); } } });</code>
php如何写 ,获取到上传的图片的二进制数据?
js部分是否有错误?
首先确保表单的属性要有enctype="multipart/form-data"
,实例化FormData不能为空啊!为空就获取不到表单值啊
用$_FILES,而不是$_POST
上传代码要写到input的“change”事件里……还有ajax的回调有点怪,都complate了就不要再判断status了吧。。
可以参考下我写的前端图片直传OSS试验
FormData
就是表单,所有数据的处理和表单是一样的,所以PHP也是一样的处理,上传文件仍然是通过$_FILES
来处理。