博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Spring MVC 学习笔记 json格式的输入和输出
阅读量:6244 次
发布时间:2019-06-22

本文共 2674 字,大约阅读时间需要 8 分钟。

  hot3.png

Spring mvc处理json需要使用jackson的类库,因此为支持json格式的输入输出需要先修改pom.xml增加jackson包的引用

org.codehaus.jackson
jackson-core-lgpl
1.8.1
org.codehaus.jackson
jackson-mapper-lgpl
1.8.1

先修改之前的helloworld.jsp,增加客户端json格式的数据输入。

var cfg =     {
type: 'POST', data: JSON.stringify({userName:'winzip',password:'password',mobileNO:'13818881888'}), dataType: 'json', contentType:'application/json;charset=UTF-8', success: function(result) { alert(result.success); } }; function doTestJson(actionName){
cfg.url = actionName; $.ajax(cfg); }

根据前面的分析,在spring mvc中解析输入为json格式的数据有两种方式 1:使用@RequestBody来设置输入

@RequestMapping("/json1")     @ResponseBody public JsonResult testJson1(@RequestBody User u){
log.info("get json input from request body annotation"); log.info(u.getUserName()); return new JsonResult(true,"return ok"); }

2:使用HttpEntity来实现输入绑定

@RequestMapping("/json2")    public ResponseEntity
testJson2(HttpEntity
u){
log.info("get json input from HttpEntity annotation"); log.info(u.getBody().getUserName()); ResponseEntity
responseResult = new ResponseEntity
( new JsonResult(true,"return ok"),HttpStatus.OK); return responseResult; }

Json格式的输出也对应有两种方式 1:使用@responseBody来设置输出内容为context body 2:返回值设置为ResponseEntity<?>类型,以返回context body 另外,第三种方式是使用ContentNegotiatingViewResolver来设置输出为json格式,需要修改servlet context配置文件如下

但这种格式的输出会返回{model类名:{内容}} 的json格式, 例如,以下代码

@RequestMapping("/json3.json") public JsonResult testJson3(@RequestBody User u){
log.info("handle json output from ContentNegotiatingViewResolver"); return new JsonResult(true,"return ok"); }

期望的返回是 {success:true,message:”return ok”}; 但实际返回的却是 {"jsonResult":{"success":true,"msg":"return ok"}} 原因是MappingJacksonJsonView中对返回值的处理未考虑modelMap中只有一个值的情况,直接是按照mapName:{mapResult}的格式来返回数据的。 修改方法,重载MappingJacksonJsonView类并重写filterModel方法如下

protected Object filterModel(Map
model) { Map
result = (Map
) super.filterModel(model); if (result.size() == 1) { return result.values().iterator().next(); } else { return result; } }

对应的ContentNegotiatingViewResolver修改如下

 

转载于:https://my.oschina.net/mayude/blog/416989

你可能感兴趣的文章
我的友情链接
查看>>
谷果等手机刷机build.prop解析
查看>>
Vbox虚拟机下 Linux网络配置
查看>>
Vmware vsphere知识中易混淆和忽略的多个概念
查看>>
Android客户端和服务端如何使用Token和Session
查看>>
Python Pycharm导入第三方包
查看>>
Nginx源码安装
查看>>
我的友情链接
查看>>
提升方法---提升方法AdaBoost方法
查看>>
Java语言的流程控制
查看>>
打乱数组(在其全排列中任选一个)Shuffle an Array
查看>>
红帆iOffice HD上线14天,Store排行榜第27位,商业类NO.1.
查看>>
我的友情链接
查看>>
nginx+django+uwsgi部署配置
查看>>
关于HWM的一些测试
查看>>
我的友情链接
查看>>
我的友情链接
查看>>
以太坊中的gas、gas price、gas limit到底是什么
查看>>
用户配置文件服务登录失败。无法加载用户配置文件
查看>>
com/android/dx/command/dexer/Main : Unsupported major.minor version 52.0
查看>>