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

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

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

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

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

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