spring mvc接收JSON格式的参数

1.配置spring解析json的库

 

  <dependency>
        <groupId>org.codehaus.jackson</groupId>
        <artifactId>jackson-mapper-asl</artifactId>
        <version>1.9.8</version>
        <type>jar</type>
        <scope>compile</scope>
    </dependency>
 

 

2.设置spring mvc 的配置文件

配置中资源解析器,messageConverters属性接收一个list,如果有其他解析器可以依次向其中添加,

不同的请求content类型spring会选择不同的解析器,解析后的内容会通过特殊的注解传送到spring mvc controller的方法中。

 

<beans:bean class="org.springframework.web.servlet.mvc.annotation.AnnotationMethodHandlerAdapter">
        <beans:property name="messageConverters">
            <util:list>
                <beans:bean id="stringHttpMessageConverter" class="com.weishu.platform.integration.support.spring.ConfigurableStringHttpMessageConverter">
                    <beans:constructor-arg value="UTF-8"/>
                </beans:bean>
               
                <beans:bean id="mappingJacksonHttpMessageConverter" class="org.springframework.http.converter.json.MappingJacksonHttpMessageConverter"/>
               
            </util:list>
        </beans:property>
    </beans:bean>

 

3.配置spring mvc controller 

使用注解@RequestBody配置参数为json对象,注意目前spring 配合 Jackson JSON库还不能正确处理泛型,如果将@RequestBody DeviceCommand[] deviceCommands 替换为List<DeviceCommand> deviceCommands ,spring 将不能将json解析为DeviceCommand对象,而是转换为LinkedHasMap对象。

 

 @RequestMapping(value = "/admin/deviceManagement/update_device_white_list_status", method = RequestMethod.POST)
 @ResponseBody
 public String updateUserWhiteListStatus(Model model, @RequestBody DeviceCommand[] deviceCommands) {
  JSONObject result = new JSONObject();
  try {
   deviceService.changeDeviceWhiteListStatus(Arrays.asList(deviceCommands));
   result.put("success", true);
  } catch (Exception e) {
   result.put("success", false);
   result.put("message", e.getMessage());
   e.printStackTrace();
  }
  return result.toJSONString();
 }

 

4.在请求中设置json对应的content类型

 

  $.ajax({
    url : 'update_device_white_list_status.service',
    dataType : 'json',
    contentType : 'application/json',
    data : $.toJSON(deviceCommands),
    success : function(e) {
     $.messager.progress('close');
     if (e.success) {
      whiteListGrid.datagrid("reload");
      $.messager.alert('成功', '操作成功', 'info');
     
     } else {
      $.messager.alert('请注意', '操作失败:' + e.message, 'error');
     }
    },
    error : function(e) {
     $.messager.progress('close');
     $.messager.alert('请注意', '操作失败:' + e.message, 'error');
    }
   });

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值