浏览器与服务器之间的数据交换有很多类型,不只是表单提交数据这一种,比如ajax技术就大量使用json、xml等,这时候就涉及到浏览器端和服务器端数据格式转换的问题,服务器端都是Java对象,需要把请求信息转为Java对象,或者把Java对象转换为响应信息,Spring提供了很重要的接口HttpMessageConverter。

这个接口有很多实现类完成信息转换,比如:
----StringHttpMessageConverter----将请求信息转为字符串
----ByteArrayHttpMessageConverter----读写二进制数据
----SourceHttpMessageConverter----读写javax.xml.transform.Source类型的数据
----XmlAwareFormHttpMessageConverter----转换部分表单数据是xml的数据
----MappingJackson2HttpMessageConverter----用Jackson开源类包读写JSON数据
----Jaxb2RootElementHttpMessageConverter----通过JAXB2读写XML数据
。。。。。。还有很多

DispatcerServlet默认装配了RequestMappingHandlerAdapter,而后者默认装配了上面前4个HttpMessageConverter

其实json跟Java对象的转换就三个要素:一个转换器,两个注解(@RequestBody、@ResponseBody)

MappingJackson2HttpMessageConverter转换json数据

这是Spring MVC默认的json转换器,虽然是默认,但还得自己导入jar包。也可以用别的转换器,后面再说

因为Spring MVC默认使用该转换器,因此applicationContext.xml中只需要配置<mvc:annotation-driven />即可

用GET或者POST提交数据的时候,HTTP请求头的Content-Type大概有以下三种:
----application/x-www-form-urlencoded:@RequestParam、@ModelAttribute、@RequestBody都可以处理
----multipart/form-data:@RequestBody没法处理
----application/json、application/xml:必须用@RequestBody处理

@RequestBody将请求信息中的json转为Java对象
@ResonseBody将处理方法返回的Java对象转为json

还以上传书籍信息为例,用ajax将书籍信息以json的格式上传,后端修改数据后转换为json传给浏览器,再显示出来

先写index.html

<!DOCTYPE html>
<html>
<head>
    <title>浏览器与服务器间用json传递数据</title>
    <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
    <script type="text/javascript" src="resources/jquery-3.1.0.js"></script>
    <script type="text/javascript" src="resources/json2.js"></script><!-- 下面的JSON.stringify()即由此js提供 -->
    <script type="text/javascript">
        
        function sendRequest(){
            var bookname=$("#bookname").val();
            var author=$("#author").val();
            var press=$("#press").val();
            var isbn=$("#isbn").val();
            var douban=$("#douban").val();
            $.ajax({       /*用jQuery发送ajax请求*/
                url:"addbook",
                type:"POST", /*注意下面的data数据部分,JSON.stringify()的作用是把json对象转为json字符串,不能少*/
                data:JSON.stringify({"bookname":bookname,"author":author,"press":press,"isbn":isbn,"douban":douban}),
                contentType:"application/json", /*将HTTP请求的Content-Type设置为“application/json”*/
                dataType:"json",
                success:function(result){
                    alert(result.bookname);
                    $("#b").html(result.bookname);
                    $("#a").html(result.author);
                    $("#p").html(result.press);
                    $("#i").html(result.isbn);
                    $("#d").html(result.douban);
                }
            });
        }
        $(function(){  /*页面载入完毕后执行这个函数*/
            $("#submit").click(sendRequest); /*为“提交”按钮绑定单击事件*/
        });
    </script>
</head>
<body>
    <div>
        书名:<input name="bookname" id="bookname" /><br>
        作者:<input name="author" id="author" /><br>
        出版社:<input name="press" id="press" /><br>
        ISBN:<input name="isbn" id="isbn"/><br>
        豆瓣评分:<input name="douban" id="douban"/><br>
        <button type="button" id="submit">提交</button>
    </div>
        <h3 style="color:red;">下面是服务器返回的信息</h3>
        <p>书名:<span id="b" style="color:red"></span></p>
        <p>作者:<span id="a" style="color:red"></span></p>
        <p>出版社:<span id="p" style="color:red"></span></p>
        <p>ISBN:<span id="i" style="color:red"></span></p>
        <p>豆瓣评分:<span id="d" style="color:red"></span></p>
</body>
</html>
<!DOCTYPE html>
<html>
<head>
    <title>浏览器与服务器间用json传递数据</title>
    <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
    <script type="text/javascript" src="resources/jquery-3.1.0.js"></script>
    <script type="text/javascript" src="resources/json2.js"></script><!-- 下面的JSON.stringify()即由此js提供 -->
    <script type="text/javascript">
        
        function sendRequest(){
            var bookname=$("#bookname").val();
            var author=$("#author").val();
            var press=$("#press").val();
            var isbn=$("#isbn").val();
            var douban=$("#douban").val();
            $.ajax({       /*用jQuery发送ajax请求*/
                url:"addbook",
                type:"POST", /*注意下面的data数据部分,JSON.stringify()的作用是把json对象转为json字符串,不能少*/
                data:JSON.stringify({"bookname":bookname,"author":author,"press":press,"isbn":isbn,"douban":douban}),
                contentType:"application/json", /*将HTTP请求的Content-Type设置为“application/json”*/
                dataType:"json",
                success:function(result){
                    alert(result.bookname);
                    $("#b").html(result.bookname);
                    $("#a").html(result.author);
                    $("#p").html(result.press);
                    $("#i").html(result.isbn);
                    $("#d").html(result.douban);
                }
            });
        }
        $(function(){  /*页面载入完毕后执行这个函数*/
            $("#submit").click(sendRequest); /*为“提交”按钮绑定单击事件*/
        });
    </script>
</head>
<body>
    <div>
        书名:<input name="bookname" id="bookname" /><br>
        作者:<input name="author" id="author" /><br>
        出版社:<input name="press" id="press" /><br>
        ISBN:<input name="isbn" id="isbn"/><br>
        豆瓣评分:<input name="douban" id="douban"/><br>
        <button type="button" id="submit">提交</button>
    </div>
        <h3 style="color:red;">下面是服务器返回的信息</h3>
        <p>书名:<span id="b" style="color:red"></span></p>
        <p>作者:<span id="a" style="color:red"></span></p>
        <p>出版社:<span id="p" style="color:red"></span></p>
        <p>ISBN:<span id="i" style="color:red"></span></p>
        <p>豆瓣评分:<span id="d" style="color:red"></span></p>
</body>
</html>

写Controller

package net.sonng.mvcdemo.controller;

import javax.servlet.http.HttpServletResponse;

import net.sonng.mvcdemo.entity.Book;

import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestBody;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.ResponseBody;

@Controller
public class BookJSONController {
    @ResponseBody  //该注解将处理方法的返回值转换为json
    @RequestMapping("/addbook") //下面的@RequestBody可以将请求内容中的json转为Java对象
    public Book editBookInfo(@RequestBody Book book ){
        book.setBookname(book.getBookname()+"----处理方法修改了数据");
        book.setAuthor(book.getAuthor()+"----处理方法修改了数据");
        book.setPress(book.getPress()+"----处理方法修改了数据");
        book.setIsbn(book.getIsbn()+"----处理方法修改了数据");
        return book;
    }
}

package net.sonng.mvcdemo.controller;

import javax.servlet.http.HttpServletResponse;

import net.sonng.mvcdemo.entity.Book;

import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestBody;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.ResponseBody;

@Controller
public class BookJSONController {
    @ResponseBody  //该注解将处理方法的返回值转换为json
    @RequestMapping("/addbook") //下面的@RequestBody可以将请求内容中的json转为Java对象
    public Book editBookInfo(@RequestBody Book book ){
        book.setBookname(book.getBookname()+"----处理方法修改了数据");
        book.setAuthor(book.getAuthor()+"----处理方法修改了数据");
        book.setPress(book.getPress()+"----处理方法修改了数据");
        book.setIsbn(book.getIsbn()+"----处理方法修改了数据");
        return book;
    }
}

浏览器访问localhost:8888/mvcdemo/index.html 输入信息后提交,下方即将服务器返回的信息列处理了

自定义JSON的HttpMessaageConverter转换器

用alibaba的fastjson:下载或者用maven引入http://maven.aliyun.com/nexus/#nexus-search;quick~fastjson 主要就是改下applicationContext.xml配置:

<mvc:annotation-driven>
    <mvc:message-converters register-defaults="false"> <!-- 不使用默认配置 -->
        <bean class="org.springframework.http.converter.StringHttpMessageConverter" />
        <bean class="org.springframework.http.converter.xml.XmlAwareFormHttpMessageConverter" />
        <bean class="org.springframework.http.converter.ByteArrayHttpMessageConverter" />
        <bean class="org.springframework.http.converter.BufferedImageHttpMessageConverter" />
        <bean class="com.alibaba.fastjson.support.spring.FastJsonHttpMessageConverter" >
            <property name="supportedMediaTypes"> <!-- 支持的媒体类型 -->
                <list>
                    <value>text/html;charset=UTF-8</value><!-- 顺序不要写反了,否则IE会出现下载提示 -->
                    <value>application/json;charset=UTF-8</value>
                </list>
            </property>
        </bean>
    </mvc:message-converters>
</mvc:annotation-driven>