JavaScript将base64图片转换成formData并通过AJAX提交的实现方法
之前为了拍摄照片使用了webcam相关的插件,其拍摄后得到的是base64格式的图片,直接显示没问题,在src中直接指定就可以了,但是要上传到server时问题就来了,server端接收的是标准的文件,也就是htmlform中type=”file”的形式。想要沿用这个接口不更改server端代码,于是尝试将base64直接转换成标准的fomeData并通过AJAX提交。
第一步,将base64转换成二进制图片(Blob)
主要思路是整理一下base64的前面几个字符,预处理以后转换成Blob对象,这个之后稍作处理可以放在formData中。
functiondataURItoBlob(base64Data){ varbyteString; if(base64Data.split(',')[0].indexOf('base64')>=0) byteString=atob(base64Data.split(',')[1]); else byteString=unescape(base64Data.split(',')[1]); varmimeString=base64Data.split(',')[0].split(':')[1].split(';')[0]; varia=newUint8Array(byteString.length); for(vari=0;i<byteString.length;i++){ ia[i]=byteString.charCodeAt(i); } returnnewBlob([ia],{type:mimeString}); }
第二步,构建formData
这里需要借助html5的canvas
varblob=dataURItoBlob(imageBase64);//上一步中的函数 varcanvas=document.createElement('canvas'); vardataURL=canvas.toDataURL('image/jpeg',0.5); varfd=newFormData(document.forms[0]); fd.append("the_file",blob,'image.png');
上面的the_file为这个文件的key,等效于input中的name,image.png则是文件名,由于base64的图片信息是不带文件名的,所以可以手动指定一个,这个参数是可选的
第三步,使用AJAX提交
为方便,这里使用jQuery的Ajax来演示,上面我们已经构建好了名为fd的formData,直接提交即可
$.ajax({ url:'http://www.example.com/upload', method:'POST', processData:false,//必须 contentType:false,//必须 dataType:'json', data:fd, success(data){ console.log(data); } });
以上所述是小编给大家介绍的JavaScript将base64图片转换成formData并通过AJAX提交的实现方法,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对毛票票网站的支持!