SpringMVC接受json参数详解

1.注解含义

  • @ResponseBody

1、概念
注解 @ResponseBody,使用在控制层(controller)的方法上。

2、作用
作用:将方法的返回值,以特定的格式写入到response的body区域,进而将数据返回给客户端。 当方法上面没有写ResponseBody,底层会将方法的返回值封装为ModelAndView对象。 如果返回值是字符串,那么直接将字符串写到客户端;如果是一个对象,会将对象转化为json串,然后写到客户端 。

3、注意编码
如果返回对象,按utf-8编码。如果返回String,默认按iso8859-1编码,页面可能出现乱码。因此在注解中我们可以手动修改编码格式,例如@RequestMapping(value="/cat/query",produces=“text/html;charset=utf-8”),前面是请求的路径,后面是编码格式。

4、原理
控制层方法的返回值是如何转化为json格式的字符串的?其实是通过HttpMessageConverter中的方法实现的,它本是一个接口,在其实现类完成转换。如果是bean对象,会调用对象的getXXX()方法获取属性值并且以键值对的形式进行封装,进而转化为json串。如果是map集合,采用get(key)方式获取value值,然后进行封装

  • @PostMapping(value="/addUser",consumes=(MediaType.APPLICATION_JSON))

1.PostMapping指定接口请求方式为post

2.value指定接口请求地址

3.consumes指定接口需要传递参数类型 默认为application/x-www-form-urlcoded

  • @RequestBody

1、@requestBody注解常用来处理content-type不是默认的application/x-www-form-urlcoded编码的内容,比如说:application/json或者是application/xml等。一般情况下来说常用其来处理application/json类型。

SpringMVC接受json参数实例

  • 准备工作

1.指定方法请求方式为post 指定@PostMapping注解
2.指定传递参数类型为json

@PostMapping(value = "/a", consumes=(MediaType.APPLICATION_JSON))

3.指定接受参数方式
通过实体类来接受json参数,这种方式适用于有对应参数得实体类

@Controller
public class PassJsonParam {
    @PostMapping(value = "/a", consumes=(MediaType.APPLICATION_JSON))
    @ResponseBody
    public Book a(@RequestBody Book book){
        System.out.println("bookId="+book.getBookId()+", author="+book.getAuthor());
        return book;
    }
}

参数样例

{
"BookId":"1",
"Author":"张三"
}

通过Map集合来接收参数,这种方式适用于没有对应实体类

@PostMapping(value = "/b", consumes=(MediaType.APPLICATION_JSON))
    @ResponseBody
    public Map<String,Object> b(@RequestBody Map<String,Object> paramsMap,){
        System.out.println(paramsMap);
        return paramsMap;
    }

参数样例

{
"userName":"liqd",
"userPwd":"123456"
}

通过List集合接收参数,适用于接受多个对象集合

  @PostMapping(value = "/c", consumes=(MediaType.APPLICATION_JSON))
    @ResponseBody
    public List<Book> c(@RequestBody List<Book> book){
        System.out.println(book);
        return book;
    }

参数样例

[
{
"BookId":"1",
"Author":"张三"
},
{
"BookId":"2",
"Author":"李四"
}
]

通过String 接收参数,这种方式适用于没有对应实体类

//注意controller中只允许有一个@RequestBody注解,通过String 参数接受会接收整个json数据,
 @PostMapping(value = "/d", consumes=(MediaType.APPLICATION_JSON))
    @ResponseBody
    public List<Book> d(@RequestBody String param){
        System.out.println(book);
        return book;
    }

注意:后台通过ReuestBody注解修饰 前端传递参数只能传递JSON字符串 而不可以传递JSON对象

var param = {"userName": "a",
            "userPwd":"b"};

data: JSON.stringify(param),
  • 2
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值