Content-type 类型
在 HTTP 协定音讯头中,应用 Content-Type 来示意媒体类型信息。它被用来通知服务端如何解决申请的数据,以及通知客户端(个别是浏览器)如何解析响应的数据,比方显示图片,解析 html 或仅仅展现一个文本等。
Post 申请的内容搁置在申请体中,Content-Type 定义了申请体的编码格局。数据发送进来后,还须要接收端解析才能够。接收端依附申请头中的 Content-Type 字段来获知申请体的编码格局,最初再进行解析。开发过程中次要有如下几种 content-type 类型:
- text/xml
该种形式次要用来提交 XML 格局的数据。 - application/x-www-form-urlencoded
浏览器的原生 form 表单,如果不设置 enctype 属性,那么最终会以 applicatiion/x-www-form-urlencoded 形式提交数据。这种形式提交数据放在 body 外面,数据依照 key1=value1&key2=value2 的形式进行编码。
- multipart/form-data
这种形式也是常见的 post 提交形式,通常表单上传时应用该办法。 - application/json
通知服务器主体的序列化的 json 字符串。
应用场景
开发过程中次要用到“application/x-www-form-urlencoded”、“application/json”、“multipart/form-data”三种类型,上面咱们就来具体说说这三种类型的构造和在 SpringMVC 中的应用场景:
### 1. application/x-www-form-urlencoded
当 action 为 get 时候,浏览器用 x -www-form-urlencoded 的编码方式把 form 数据转换成一个字串(name1=value1&name2=value2…),而后把这个字串 append 到 url 前面,用? 宰割,加载这个新的 url。当 action 为 post 时候,浏览器把 form 数据封装到 http body 中,而后发送到 server
客户端:
header:Content-Type=application/x-www-form-urlencoded
Method:get 办法 - 参数须要做 URLEncode
Post 办法 - 构建 nameValuePairList 列表放入 UrlEncodedFormEntity
List<NameValuePair> nameValuePairList = new ArrayList<~>();
nameValuePairList.add(new BasicNameValuePair( name: "name", value: "zhangsan"));
nameValuePairList.add(new BasicNamevaluePair( name: "birthday" value: "1990-08-25"));
UrlEncodedFormEntity entityParam = new UrlEncodedFormEntity(namevaluePairlist,charset: "UTF-8");
post.setEntity(entityParam);
服务端:
申请参数不含 MultlpartFile 类型时可同时反对 GET 和 POST,具体请参考以下标准:controller 办法注解 @RequestMapping(method = {RequestMethod.POST, RequestMethod.GET})
上传文件:只反对 POST(包含 MutipleFile 和 Base64 字符串)办法参数能够对象形成:不能加 @RequestBody 注解,否则不能接管到
@RequestMapping(value = "/testParamForm", method = {RequestMethod.POST,RequestMethod.GET})
@ApiOperation("Content-type:application/x-www-form-urlencoded, 同时反对 POST 和 GET,多个申请参数,无上传文件,URL 和 body 的申请参数能够失常获取,URL 的参数 encode 转码")
@ApiResponses(value={@ApiResponse(code = 200, message = "申请胜利")})
public Result testParamForm(String name, String idcard){log.info("name:{}, idcard:{}", name, idcard);
return ResultUtil.success();}
如果是申请参数超过 3 个以上,能够封装成申请参数对象:
@RequestMapping(value = "/testObjForm", method = {RequestMethod.POST,RequestMethod.GET})
@ApiOperation("Content-type:application/x-www-form-urlencoded, 同时反对 POST 和 GET,封装申请参数对象,无上传文件")
@ApiResponses(value={@ApiResponse(code = 200, message = "申请胜利")})
public Result testObjForm(IdcardRequestDto idcardRequestDto){log.info("name:{}, idcard:{}, file: {}", idcardRequestDto.getName(), idcardRequestDto.getIdcard(), idcardRequestDto.getFile());
return ResultUtil.success();}
### 2. application/json
客户端:
header:Content-Type=application/json
Mehthod:POST
申请参数 json 字符串,格局如:"{\"name\":\" 张三 \"}",可通过构建 map 对象后再转换成 json 字符串:JSONObject.toJSONString(map)
服务端:
Method 只反对 POST @RequestMapping(method = {RequestMethod.POST})
办法参数能够对象形成:加 @RequestBody 注解前缀,否则不能接管到
文件上传能够通过转换成 base64 参数
@RequestMapping(value = "/testJson", method = {RequestMethod.POST})
@ApiOperation("Content-type:application/json, 只反对 POST,申请参数能够是对象,List,Map,如有上传文件,需转换成 Base64 字符串")
@ApiResponses(value={@ApiResponse(code = 200, message = "申请胜利")})
public Result testJson(@RequestBody IdcardRequestDto idcardRequestDto){log.info("name:{}, idcard:{}, file: {}", idcardRequestDto.getName(), idcardRequestDto.getIdcard(), idcardRequestDto.getFile());
return ResultUtil.success();}
### 3. multipart/form-data
当申请参数有上传文件,3 个及以下申请参数,只反对 POST 申请,客户端设置申请头参数:“Content-type: multipart/form-data”:
@RequestMapping(value = "/testMutipartParamForm", method = {RequestMethod.POST})
@ApiOperation("Content-type:application/x-www-form-urlencoded, 只反对 POST,多个申请参数,有上传文件")
@ApiResponses(value={@ApiResponse(code = 200, message = "申请胜利")})
public Result testMutipartParamForm(String name, String idcard, MultipartFile file){log.info("name:{}, idcard:{}, file: {}", name, idcard, file);
return ResultUtil.success();}
当申请参数有上传文件,3 个以上申请参数,封装成申请对象,不能加 @RequestBody 注解,只反对 POST 申请,客户端设置申请头参数:“Content-type: multipart/form-data”
@RequestMapping(value = "/testMutipartObjForm", method = {RequestMethod.POST})
@ApiOperation("Content-type:application/x-www-form-urlencoded, 只反对 POST,封装申请参数对象,有上传文件")
@ApiResponses(value={@ApiResponse(code = 200, message = "申请胜利")})
public Result testMutipartObjForm(IdcardRequestDto idcardRequestDto){log.info("name:{}, idcard:{}, file: {}", idcardRequestDto.getName(), idcardRequestDto.getIdcard(), idcardRequestDto.getFile());
return ResultUtil.success();}
本案例来自于昂焱数据,更多精彩请拜访 https://www.ayshuju.com/