application/x-www-form-urlencoded与application/json

application/x-www-form-urlencodedapplication/json

http请求 
场景: 
前端:SDK通过http发送请求/页面Ajax提交。 
后台:Springboot服务,Rest风格,需在controller层之前拦截请求。

Springboot支持Rest风格给编码带来了很好的便捷性,@RequestBody让我们可以直接以application/json请求并在到达controller层获得已反序列化的对象,当有拦截的需求,这种方式却不再奏效。

application/x-www-form-urlencoded通过表单提交,在sevlet实现中,mutipart/form-dataapplication/x-www-form-urlencoded会被特殊处理,请求参数将被放置于request.paramter,这是一个map。我们可以从map中获取参数进行验证,或者其他拦截需求,map的获取类似hibernate的延迟加载,当调用request.getparamter()方法,servlet才会从请求流中读取请求参数加载入mapInputStream也会存有这份数据,但如果这份数据被读取,那么到了controller层将无法读出数据,同样,拦截之后到达controller层时请求数据已经被加载入了controller层方法实参,实参对象需要有set方法,框架会以反射的方式调用属性的set方法注入数据,数据只会被注入到已有的属性。

当以application/jsoncontent-type传送数据,被传送的对象只需被json序列化。当以application/x-www-form-urlencoded的方式传送数据。请求的内容需要以..=..&..=..的格式提交,在请求体内内容将会以”&”和“ = ”进行拆分。

 

当我们使用content-type=application/json且后台使用@RequestBody,则无法再从request.paramter中获取请求数据。

 

如果数据是简单、平面的key-value数值对,那么使用www-form-urlencoded简单实用,不需要额外的编解码;

如果数据是复杂的嵌套关系,有多层数据,那么使用application/json会简化数据的处理

选择application/x-www-form-urlencoded还是application/json,得看你是否有从request.paramter获取请求数据的需求。


猜你喜欢

转载自blog.csdn.net/caodongfang126/article/details/78952692