springmvc接收参数的方法

本文详细解析了HTTP请求中四种Body类型:form-data、x-www-form-urlencoded、raw和binary的区别与使用场景。重点介绍了它们如何处理不同格式的数据,如文件上传、键值对和二进制数据。

1.首先说下postman中 form-data、x-www-form-urlencoded、raw、binary对应的各种使用方法及区别

1、form-data: 

                   就是http请求中的multipart/form-data,它会将表单的数据处理为一条消息,以标签为单元,用分隔符分开。既可以上传键值对,也可以上传文件。当上传的字段是文件时,会有Content-Type来说明文件类型;content-disposition,用来说明字段的一些信息;

由于有boundary隔离,所以multipart/form-data既可以上传文件,也可以上传键值对,它采用了键值对的方式,所以可以上传多个文件。

 

                 

2、x-www-form-urlencoded:

             就是application/x-www-from-urlencoded,会将表单内的数据转换为键值对,比如,name=java&age = 23

 

3、raw

            可以上传任意格式的文本,可以上传text、json、xml、html等

4、binary

          相当于Content-Type:application/octet-stream,从字面意思得知,只可以上传二进制数据,通常用来上传文件,由于没有键值,所以,一次只能上传一个文件。

multipart/form-data与x-www-form-urlencoded区别

               multipart/form-data:既可以上传文件等二进制数据,也可以上传表单键值对,只是最后会转化为一条信息;

               x-www-form-urlencoded:只能上传键值对,并且键值对都是间隔分开的。

curl http://127.0.0.1:8080/hello -d "name=99"  //这样发出的就是content-type:applicationx-www-form-urlencoded的消息

curl -H "content-type:application/json"

 

参考:https://blog.youkuaiyun.com/ggaofengg/article/details/78566225

GET、POST方式提交的请求:

Content-type:

1、application/x-www-form-urlencoded:@RequestBody不是必须加的

2、mutipart/form-data:@RequestBody不能处理这种格式

3、其他格式,比如application/json,application/xml等,必须使用@RequestBody来处理

PUT方式提交的请求:

以上1和3的场景都是必须使用@RequestBody来处理的,2场景也是不支持的

前端代码如下:(这里必须将JSON对象使用JSON.stringify()转为JSON字符串再传递,否则后台接收不到值)

$.ajax({
    url:"../../Notice/LoadForm.do",
    type:"post",
    contentType:"application/json;charset=UTF-8",
    data:JSON.stringify({"id":"1","title":"标题"})
});

后台接收代码示例

@RequestMapping(value="Notice/LoadForm")
@ResponseBody
public ResultJO loadForm(@RequestBody Notice notice){

}

参考:https://www.cnblogs.com/anai/p/4272573.html

### Spring MVC 参数绑定及接收方法 Spring MVC 提供了多种方式来实现参数的绑定和接收,这些功能使得开发者可以灵活地处理来自客户端的各种请求数据。 #### 1. 使用基本类型的参数 当 URL 中携带简单的键值对参数时,可以直接通过控制器方法中的形参名匹配的方式完成绑定。例如: ```java @RequestMapping("/getSimpleParam") public String getSimpleParam(String param) { return "param:" + param; } ``` 这种方式适用于单个简单类型的数据绑定[^3]。 #### 2. 数组类型的参数绑定 对于多值参数的情况,默认情况下可以通过数组的形式接收。例如: ```java @RequestMapping("/getNameArray") public String getNameArray(String[] names) { return "names:" + Arrays.toString(names); } ``` 上述代码展示了如何通过 `String[]` 类型接收多个同名参数。 #### 3. 列表类型的参数绑定 如果希望将多值参数绑定到 `List<T>` 上,则需要显式声明 `@RequestParam` 注解并指定其泛型类型。例如: ```java @RequestMapping("/getListName") public String getListName(@RequestParam List<String> listName) { return "listName:" + listName; } ``` 这里的关键在于使用了 `@RequestParam` 来明确告诉框架该参数是一个列表形式的数据[^1]。 #### 4. 对象类型的参数绑定 除了基础类型外,还可以直接将整个对象作为入参传入。此时,Spring MVC 自动会尝试把请求体内的字段映射至目标类实例中对应的属性上去。比如定义了一个 User 实体类之后,在 Controller 层就可以这样写: ```java @RequestMapping(value = "/saveUser", method = RequestMethod.POST) public ResponseEntity<?> saveUser(User user){ userService.save(user); return new ResponseEntity<>(HttpStatus.CREATED); } ``` 此场景下假设前端发送 JSON 数据过来的话,那么后台就能自动解析成 JavaBean 形式的实体对象[^4]。 #### 5. 复杂结构(嵌套集合)的参数绑定 针对更复杂的业务需求,可能涉及到深层级的对象或者含有动态大小容器成员变量的情形。这时同样依赖于标准注解配合自定义转换器机制共同作用达成目的。举个例子来说就是下面这种情形——即内部还包含了另一个子集合作为组成部分的大对象: ```java @RequestMapping("/complexObject") public void complexObject(ComplexEntity entity){ System.out.println(entity); } // ComplexEntity.java class ComplexEntity{ private List<Item> items; // Getter & Setter omitted for brevity. static class Item{ private String name; // Getter & Setter also omitted here... } } ``` 以上情况表明即使面对较为棘手的数据模型设计也能够妥善解决它们之间的关联问题。 #### 总结 综上所述,Spring MVC 支持多种形式的参数绑定策略,无论是单一值还是批量数据都能很好地适配实际应用场景下的各种可能性。同时借助强大的扩展能力还能进一步满足特殊定制化的需求。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值