SpringMVC的JSON处理及FastJSON的整合使用(七)下

简介: SpringMVC的JSON处理及FastJSON的整合使用(七)

二.十 JSON 的key/value 形式传入。


1 . 在后端的时候,不用@RequestBody 注解了,只需要用@ResponseBody 注解即可。


@RequestMapping(value="toLogin")
  public String toLogin(){
    return "user/login2";
}
@RequestMapping(value="/keyJson")
  public @ResponseBody User getKeyUser(User user){
    System.out.println("前台传过来的值是:"+user.toString());
    user.setName("我是老蝴蝶Key"); //改变前台传过来的值
    user.setId(1); //添加新的属性值
    return user;
  }


2 .前台页面


<body>
  <h2>两个蝴蝶飞欢迎你</h2>
  <span id="name"></span> <br>
  <span id="sex"></span> <br>
  <span id="description"></span> <br>
  <span id="id"></span> <br>
  <button onclick="execKeyValueJSON()">执行keyValueJson</button>
  <script type="text/javascript">
    function execKeyValueJSON(){
      //注意,这个时候传入的是字符串。
      var user="name='两个蝴蝶飞KeyValue'&sex=24&description='一个快乐的程序员keyValue'";
      //2。 执行ajax程序 
      $.ajax({
        type:"post", 
        url:"keyJson.action",  //注意请求路径
        data:user,
        success:function(data){
          $("#name").html(data.name);
          $("#sex").html(data.sex);
          $("#description").html(data.description);
          $("#id").html(data.id);
        }
      })
    }
  </script>
</body>


3 . 运行服务器,进行测试。


20190826173011450.png

控制台打印输出


20190826173114860.png


前端数据展示


20190826173050459.png


响应数据类型返回


20190826173058360.png


二.十一 返回集合类型 如List


采用 key/value 的形式进行讲解。


1 . 后端数据 返回


@RequestMapping(value="toLogin")
  public String toLogin(){
    return "user/login2";
}
@RequestMapping(value="/listJson")
  public @ResponseBody List<User> getUserList(User user){
    List<User> userList=new ArrayList<User>();
    User user0=new User();
    user0.setName("两个蝴蝶飞");
    user0.setDescription("一个快乐的程序员");
    userList.add(user0);
    User user1=new User();
    user1.setName("精灵妹");
    user1.setDescription("一个快乐的精灵");
    userList.add(user1);
    User user2=new User();
    user2.setName("老蝴蝶");
    user2.setDescription("一个快乐的老蝴蝶");
    userList.add(user2);
    User user3=new User();
    user3.setName("精小妹");
    user3.setDescription("一个快乐的精小妹");
    userList.add(user3);
    return userList;
  }


2 . 前端页面展示


<body>
  <h2>两个蝴蝶飞欢迎你</h2>
  <div id="listJson">
  </div>
  <button onclick="execListJSON()">执行listJson</button>
  <script type="text/javascript">
    function execListJSON(){
      //1。定义对象
      var user="name='两个蝴蝶飞KeyValue'&sex=24&description='一个快乐的程序员keyValue'";
      //2。 执行ajax程序 
      $.ajax({
        type:"post", 
        url:"listJson.action",  //注意请求路径
        data:user,
        success:function(data){
          var str="<table><tr><th>姓名</th><th>描述</th></tr>";
          $.each(data,function(idx,item){
            str+="<tr>";
            str+="<td>"+item.name+"</td>";
            str+="<td>"+item.description+"</td>";
            str+="</tr>";
          })
          str+="</table>";
          $("#listJson").append(str);
        }
      })
    }
  </script>
</body>


3 . 运行服务器


20190826173125481.png


前端数据展示为:


20190826173130158.png


响应数据类型


20190826173147811.png


响应数据:


20190826173142323.png


三. SpringMVC与fastjson 进行整合


三.一 添加fastjson 的jar包。


注意,在添加fastjson jar包之前,一定要去除掉以前的jackson 的jar包,不然还是会默认加载的。这一点是非常重要的。


20190826173147811.png


三.二 修改json 方式为fastjson


<!-- 设置fastjson的配置方案 -->
    <mvc:annotation-driven>
      <!-- 设置不使用默认的消息转换器 -->
        <mvc:message-converters register-defaults="false">
          <!-- 配置Spring的转换器 -->
          <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"/>
            <!-- 配置fastjson中实现HttpMessageConverter接口的转换器 -->
            <bean id="fastJsonHttpMessageConverter" 
              class="com.alibaba.fastjson.support.spring.FastJsonHttpMessageConverter">
                <!-- 加入支持的媒体类型:返回contentType -->
                <property name="supportedMediaTypes">
                    <list>
                        <!-- 这里顺序不能反,一定先写text/html,不然ie下会出现下载提示 -->
                       <value>text/html;charset=UTF-8</value>
                        <value>application/json;charset=UTF-8</value>
                    </list>
                </property>
         <!-- 可添加其他的属性来扩展功能,如日期 -->
                 <property name="features">
                    <list>
                    <!-- 默认的意思就是不配置这个属性,配置了就不是默认了 -->
                       <!-- 是否输出值为null的字段 ,默认是false-->
                        <value>WriteMapNullValue</value>
                        <value>WriteNullNumberAsZero</value>
                        <value>WriteNullListAsEmpty</value>
                        <value>WriteNullStringAsEmpty</value>
                        <value>WriteNullBooleanAsFalse</value>
                        <value>WriteDateUseDateFormat</value>
                    </list>
                </property>
            </bean>
        </mvc:message-converters>
    </mvc:annotation-driven>


三.三 后端处理


@RequestMapping(value="/listJson",produces={"application/json"})
  public @ResponseBody List<User> getUserList(User user){
    List<User> userList=new ArrayList<User>();
    User user0=new User();
    user0.setName("两个蝴蝶飞");
    user0.setDescription("一个快乐的程序员");
    userList.add(user0);
    User user1=new User();
    user1.setName("精灵妹");
    user1.setDescription("一个快乐的精灵");
    userList.add(user1);
    User user2=new User();
    user2.setName("老蝴蝶");
    user2.setDescription("一个快乐的老蝴蝶");
    userList.add(user2);
    User user3=new User();
    user3.setName("精小妹");
    user3.setDescription("一个快乐的精小妹");
    userList.add(user3);
    return userList;
  }


注意,此时一定不要忘记用 produces 的属性,否则会按照 springmvc.xml 中的supportedMediaTypes 第一个属性值即text/html 进行解析。


三.四 前端页面显示


与 二.十一 的前端显示是一样的,回过来的数据就是 json对象了。


三.五 重启服务器,进行验证。


20190826173215141.png


在这里插入图片描述


当然,也可以返回单个bean 对象值。 也需要写 produces 的属性值。


@RequestMapping(value="/responseJson",produces={"application/json"})
  public @ResponseBody User getResponseUser(@RequestBody User user){
    System.out.println("前台传过来的值是:"+user.toString());
    user.setName("我是老蝴蝶"); //改变前台传过来的值
    user.setId(1); //添加新的属性值
    return user;
  }


前端的话,与 二.八 章节的前端的值一致。 这里不再重复写。


谢谢!!!

相关文章
|
4月前
|
XML JSON JavaScript
javaweb实训第六天上午——JSON&SpringMVC进阶(1)
1.课程介绍 JSON; (了解) SpringMVC返回JSON; (掌握) SpringMVC文件上传、下载; (掌握) SpringMVC拦截器; (掌握) SpringMVC执行流程; (掌握) 2.JSON 2.1.JSON概述
58 0
|
5月前
|
JSON JavaScript fastjson
SpringMVC原理分析 | JSON、Jackson、FastJson
SpringMVC原理分析 | JSON、Jackson、FastJson
66 0
|
6月前
|
存储 JSON 前端开发
SpringMVC之JSON返回&异常处理机制(带你学习新的SpringMVC武功秘籍)
SpringMVC之JSON返回&异常处理机制(带你学习新的SpringMVC武功秘籍)
84 0
|
6月前
|
XML JSON 开发框架
【推荐】SpringMVC与JSON数据返回及异常处理机制的使用
【推荐】SpringMVC与JSON数据返回及异常处理机制的使用
72 0
|
5月前
|
JSON 数据格式
SpringMVC-接收请求中的json数据及日期类型参数传递
SpringMVC-接收请求中的json数据及日期类型参数传递
54 0
|
6月前
|
JSON 前端开发 Java
SpringMVC之JSON返回及异常处理机制
SpringMVC之JSON返回及异常处理机制
34 0
|
3月前
|
JSON fastjson Java
FastJSON操作各种格式的JSON数据
FastJSON处理各种格式的JSON数据
|
4月前
|
JSON fastjson 数据库
字符编码导致Rapidjson(腾讯开源的json解析库)到Fastjson(阿里开发的Java json解析库)转换失败的原因分析
最近在客户端的开发的过程中,使用到了RapidJson,公司的开发是客户端和数据库端都由不同的人进行开发,我负责的客户端的逻辑开发(使用c++),开发工具同时使用了VS2017和QT的编译环境,使用QT主要是为了客户端界面开发方便,而使用了VS环境主要是维护公司开发的数据库接口库,这个库的唯一作用就是作为一个中间桥梁,使用Rapidjson将数据库接口的json数据格式解析为结构体数据,从而在客户端界面进行展示,或者接收客户端的数据,使用Rapidjson将其转换为json数据,发送给数据库接口以保存数据使用 。不太明白的可以参考我上一篇文章说明Rapidjson的使用过程-Parse解析数组
59 0
|
4月前
|
JSON 前端开发 Java
javaweb实训第六天上午——JSON&SpringMVC进阶(2)
5.SpringMVC拦截器 5.1.创建拦截器
56 0
|
5月前
|
JSON 数据格式
SpringMVC JSON数据交互 数据不回显问题
SpringMVC JSON数据交互 数据不回显问题
28 1