• 前端基础一:用Formdata对象来上传图片的原因


    最近有人问:你是否能用json来传图片,其实应该这么理解就对了。

    一、上传的数据体格式Content-Type

    •         1.application/x-www-form-urlencoded 
    •         2.application/json
    •         3.multipart/form-data

            以上三种类型旨在告诉服务器需要接收的数据类型同事要采用何种类型的解析方式。

    二、理解常见的三种Content-Type

    application/x-www-form-urlencoded :会在url上拼接字符串,如:k=123&c=12241,同时对于中文还会转码。
    application/json:直接会在请求体中 添加object对象 如: { a: 123, b: 456 }
    multipart/form-data: 在network中可以看到添加带数据类型等各类标识的文件类型字符串请求体 告诉服务器端接收对象是一个文件数据流


    三、如果采用JSON来传递file会发生什么

            模拟一次input文件上传:

    1. input type="file" id="file" multiple onchange="change(this)"/>
    2. <script>
    3. var json = {}
    4. function change(t,event){
    5. console.log(t.files)
    6. console.log(t.value)
    7. json.file = t.files[0]
    8. console.log(json);
    9. }
    10. script>

    得到的只是一个描述性JSON对象,根本就不是一个文件对象。
    如果说一定得需要用json来传递的话,那么就必须得把这个原生的file对象进行转码,例如:base64,然后后端在接收的时候按照json来解析,获取那一段字符串之后重新转码生成图像文件,过程确实繁琐了。 

    四、采用FormData

             采用formdata的话会把本次所有的form表单统一作为一个类型去发送,例如form action enctype采用FormData数据对象,那么在解析的时候就很好解析了,接收的是文件流,那么也是按文件流进行处理,服务端与客户端都省事了。

  • 相关阅读:
    Echarts 3D饼图开发
    图论_2。
    arraybuffer 转json
    操作系统(2.8)--线程的实现
    《C++ primer plus》第7章:函数——C++的编程模块
    DDoS攻击与CC攻击:网络安全的两大挑战
    老卫带你学---leetcode刷题(33. 搜索旋转排序数组)
    如何在本地使用Docker搭建和运行Kubernetes集群
    Python自动化测试之request库(五)
    There are not enough slots available in the system to satisfy the 48 slots报错
  • 原文地址:https://blog.csdn.net/2201_75705263/article/details/133832340