ICode9

精准搜索请尝试: 精确搜索
首页 > 其他分享> 文章详细

图片上传转换成Base64,然后再转成 file 提交给后端

2022-07-21 16:05:04  阅读:167  来源: 互联网

标签:console file form Base64 bytes Base64Val 转成 var new


图片上传代码转换成Base64

<input type="file" name="upimg" id='upimg'>

<script>
  window.onload = () => {
    let upDOM = document.getElementById('upimg')
    upDOM.addEventListener('change', (e) => {
      console.log(e)
      console.log(upDOM.files[0])
      var reader = new FileReader();
      reader.readAsDataURL(upDOM.files[0]);
      
      reader.onload = function (ie) {
        var Base64Val = this.result;
        console.log('Base64')

        console.log(Base64Val)
      }
    })
  }
</script>

 

将Base64格式的图片转换成file提交给后端

  // Base64Val  base64格式的图片
      // fileName   生成文件的名字 (可自定义)

      var bytes=window.atob(Base64Val.split(',')[1]);
      var ab = new ArrayBuffer(bytes.length);  
      var ia = new Uint8Array(ab);  
      for (var i = 0; i < bytes.length; i++) {  
          ia[i] = bytes.charCodeAt(i);  
      }
      this[fileName] = new File( [ab] , fileName , {type : 'image/png'})



OR

/**  
 * @param base64Codes  
 *            图片的base64编码  
 */  
function sumitImageFile(base64Codes){  
    var form=document.forms[0];  

    var formData = new FormData(form);   //这里连带form里的其他参数也一起提交了,如果不需要提交其他参数可以直接FormData无参数的构造函数  

    //convertBase64UrlToBlob函数是将base64编码转换为Blob  
    formData.append("imageName",convertBase64UrlToBlob(base64Codes));  //append函数的第一个参数是后台获取数据的参数名,和html标签的input的name属性功能相同  

    //ajax 提交form  
    $.ajax({  
        url : form.action,  
        type : "POST",  
        data : formData,  
        dataType:"text",  
        processData : false,         // 告诉jQuery不要去处理发送的数据  
        contentType : false,        // 告诉jQuery不要去设置Content-Type请求头  

 

更多内容请见原文,原文转载自:https://blog.csdn.net/weixin_44519496/article/details/120055802

标签:console,file,form,Base64,bytes,Base64Val,转成,var,new
来源: https://www.cnblogs.com/wangchuanxinshi/p/16502206.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有