首页   注册   登录
V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
宝塔
V2EX  ›  Java

关于前端传参问题: formData 和 json 两者有什么优劣吗?或者说存在决定性优势

  •  1
     
  •   a7217107 · 37 天前 · 3513 次点击
    这是一个创建于 37 天前的主题,其中的信息可能已经有所发展或是发生改变。

    前两天根据项目后端接参问题跟同事讨论,既有 formData 又有 json,比较混乱。我的观点是 json 对于接复杂对象比较方便,formdata 需要 String 转成对象,同时参考了一些开源项目,请求封装默认的是 json 格式。同事认为,请求方式只是一种跟前端的约定,json 格式 postman 自测太麻烦,绝大多数接口 formData,遇到复杂格式的 json 接参或者 String 转对象。

    34 回复  |  直到 2019-10-15 11:05:43 +08:00
        1
    murmur   37 天前   ♥ 1
    json 格式 postman 怎么麻烦了,直接写到 body 里,加个 type 头就完了
        2
    a62527776a   37 天前
    我们公司后端也是一会儿一种 烦死了
        3
    wunonglin   37 天前
    前端完全抛弃 formData 是可行的,只不过大多数后端框架自带了 formData 解析相对方便而已,其实是有 json 的传入参数校验之类的,class-validator 就是,只不过他们懒得。。。
        4
    liuhuansir   37 天前
    感觉两者区别不大,只要统一成一种就行,两种混搭最烦
        5
    droiz   37 天前 via iPhone
    不涉及上传文件那随便,上传文件还是得 formData
        6
    arrow8899   37 天前
    form-data 和 json 在表示同样的信息时,form-data 数据量会小一点(a=1&b=2) 7Byte,但是 json 可读性更好({"a":1,"b":2}) 13Byte。除此之外,区别不大,只要前后端约定好就行。
        7
    userdhf   37 天前
    post 只能用 formdata 吗?
        8
    zivyou   37 天前
    上传文件只能用 form-data
        9
    Vegetable   37 天前
    主要是 form 传递二进制比较方便,不然可以完全舍弃。json 上传文件不是很合适。
        10
    hmxxmh   37 天前 via Android
    @murmur 哈哈,可能他没试过
        11
    Sapp   37 天前
    现在不是只有上传文件才用 form-data 吗?
        12
    Kusoku   37 天前
    postman 自测真的不麻烦啊
        13
    Chingim   37 天前
    用 json, 便于调试 /抓包 /debug
        14
    harde   37 天前
    后端偷懒了,我设计接口都是兼容 formData 与 json 的。
        15
    barbery   37 天前
    formData 只能是传递 string 格式的参数,类似 go 这类的静态语言,如果传 json 的话可以省下不少类型转换的麻烦
        16
    maemual   37 天前
    差别不大,统一成一种就行。。。
        17
    KuroNekoFan   37 天前
    你指的 formdata,是 application/x-www-form-urlencoded 吧
        18
    Krime   37 天前
    formData 传数组和多维数据的时候比较捉急,但是更适合上传文件
        19
    ijse   37 天前
    formdata 对数组的编码方式还有很多种方式,常常会因为不统一引起麻烦,不如 json 更标准
        20
    ipwx   37 天前 via Android
    对象一复杂,formdata 你就哭吧
        21
    wisetc   37 天前 via iPhone
    不是两种方式都应该同时支持吗,任意调用者用着舒服就用哪种,现在大部分都支持 raw json contentType 吧。
        22
    optional   37 天前 via iPhone
    前者可以传文件,后者保持结构和类型
        23
    walpurgis   37 天前
    Content-Type 是 json 的时候,cors 会多触发一次预检请求
        24
    zhengjian   37 天前
    @walpurgis 你指的是 options 方法吗,应该跟 Content-Type 没关系吧?
        25
    lihongjie0209   37 天前
    @harde #14 这个问题基本和开发无关, 取决你的用的 mvc 框架是否支持。
        26
    jorneyr   37 天前
    FormData 方便 XSS 过滤,但是传复杂对象 (多级属性) 麻烦
    JSON 传复杂对象方便,但是 XSS 过滤麻烦
        27
    harde   37 天前
    @lihongjie0209 框架不支持就不能自己写了?写个过滤器一劳永逸。
        28
    lihongjie0209   37 天前
    @harde #27 那么你还需要定义一套 formdata 字段解析的规则 ?

    类似于 reqObject[listField][index_1][objectfield] = 1 ?? 这样的?
        29
    DOLLOR   37 天前 via Android
    FormData 传简单的 key-value 挺方便的,但是嵌套对象、数组就比较麻烦了。所以要根据你的情况考虑选择。
        30
    mmrx   37 天前
    有必要统一么,我前后端客户端都写,参数简单就用 FromData,复杂参数就用 Json 格式传参
    根据实际情况选用就好了,或者有偏好+自己可以决定用什么格式的话,想用什么格式用什么格式
    否则,还是看清接口文档,参数格式到底是啥,反正也没有决定权...
        31
    jzmws   37 天前
    @harde 这么写的 ? 有例子不 ?
        32
    ma836323493   37 天前 via Android   ♥ 2
    传什么都好,别再给我传 undefined 了,脑壳疼
        33
    Takamine   36 天前 via Android
    还是除了文件上传之外统一 json 吧。
        34
    SkyLine7   36 天前
    文件上传,formData,其他一律 json 或者 urlencoding
    关于   ·   FAQ   ·   API   ·   我们的愿景   ·   广告投放   ·   感谢   ·   实用小工具   ·   3160 人在线   最高记录 5043   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.3 · 25ms · UTC 10:31 · PVG 18:31 · LAX 02:31 · JFK 05:31
    ♥ Do have faith in what you're doing.