json数据交互与@RequestBody

本文详细介绍了SpringMVC框架中@RequestBody注解的使用方法,包括如何通过该注解将HTTP请求体中的JSON数据转换为Java对象,并在Controller中进行处理。同时,文章还提供了从添加依赖、编写Action、Model到配置JSON转换器的完整步骤。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

@RequestBody

@RequestBody注解用于读取http请求的内容(字符串),通过springmvc提供的HttpMessageConverter接口将读到的内容(json数据)转换为java对象并绑定到Controller方法的参数上。传统的请求参数:
itemEdit.action?id=1&name=zhangsan&age=12
现在的请求参数:
使用POST请求,在请求体里面加入json数据
 

{
"id": 1,
"name": "测试商品",
"price": 99.9,
"detail": "测试商品描述",
"pic": "123456.jpg"
}

请求json,响应json实现

1.加入jar包

https://download.youkuaiyun.com/download/badao_liumang_qizhi/10689053

2.编写action

//json数据交互
 @RequestMapping(value = "/json.action")
 public @ResponseBody
 Items json(@RequestBody Items items){
  
  return items;
 }

3.编写model

public class Items {
    private Integer id;

    private String name;

    private Float price;

    private String pic;

    private Date createtime;

    private String detail;
  

    省略get  set方法

3.编写jsp

这里不加触发事件,直接页面加载完就出发,接受到json数据后也不处理,直接返回。

<script type="text/javascript">
$(function(){
 var params = '{"id": 1,"name": "测试商品","price": 99.9,"detail": "测试商品描述","pic": "123456.jpg"}';
 $.ajax({
  url : "${pageContext.request.contextPath }/json.action",
  data : params,
  contentType : "application/json;charset=UTF-8",//发送数据的格式
  type : "post",
  dataType : "json",//回调
  success : function(data){
   alert("获取到的数据的name为:"+data.name);
  }
  
 });
});
</script>

4.配置json转换器

如果不使用注解驱动<mvc:annotation-driven />,就需要给处理器适配器配置json转换器。

在springmvc.xml配置文件中,给处理器适配器加入json转换器:

<!--处理器适配器 -->
 <bean class="org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerAdapter">
  <property name="messageConverters">
  <list>
  <bean class="org.springframework.http.converter.json.MappingJacksonHttpMessageConverter"></bean>
  </list>
  </property>
 </bean>

成功后回调,将传回来的数据赋给形参data,此时data可以直接调用model 的属性。

完成最简单的前后端数据交互。

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

霸道流氓气质

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值