Spring MVC(四)JSON数据交换

一、JSON概述

JSON (JavaScript Object Notation, js对象标记)是一种轻量级的数据交换格式。基于纯文本的数据格式。

JSON有两种数据结构:

  1. 对象结构

    对象结构以“{“开始,以”}”结束。中间由0个或多个“,”分隔。其中key必须是String类型,value可以是其他类型。
    在这里插入图片描述
    语法结构: {
    key1:value1,
    key2:value2,
    …,
    key:value
    }

  2. 数组结构
    数组结构以“[”开始,以“]”结束。中间由0个或多个“,”分隔
    在这里插入图片描述
    语法结构:[
    value1,
    value2,

    value
    ]

  3. 复杂数据结构(上面两种进行组合)
    在这里插入图片描述

二、JSON数据转换

Spring提供了HttpMessageConverter接口来实现浏览器与Controller之间的数据交换,而默认处理JSON格式请求的实现类是MappingJackson2HttpMessageConverter
在这里插入图片描述
要使用该类,要引入Jackson的开源包(下载地址
在这里插入图片描述

三、示例

1、导包
在这里插入图片描述
2、编写web.xml

   <servlet>
       <servlet-name>springmvc</servlet-name>
       <servlet-class>
           org.springframework.web.servlet.DispatcherServlet
       </servlet-class>
       <init-param>
           <param-name>contextConfigLocation</param-name>
           <param-value>classpath:springmvc-config.xml</param-value>
       </init-param>
       <load-on-startup>1</load-on-startup>
   </servlet>
    <servlet-mapping>
        <servlet-name>springmvc</servlet-name>
        <url-pattern>/</url-pattern>
    </servlet-mapping>

3、编写springmvc-config.xml

    <!-- 定义扫描包 -->
    <context:component-scan base-package="controller"></context:component-scan>
    <!-- 定义视图解析器 -->
    <bean id="viewResolver"
          class="org.springframework.web.servlet.view.InternalResourceViewResolver">
        <property name="prefix" value="/WEB-INF/jsp/" />
        <property name="suffix" value=".jsp" />
    </bean>
    <!-- 注解 -->
    <mvc:annotation-driven />
    <!-- 前端过滤 -->
    <mvc:default-servlet-handler/>

4、编写页面index.jsp

<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<script type= "text/javascript" src="${pageContext.request.contextPath}/static/js/jquery.min.js"></script>
<script type= "text/javascript">
    function clickJson() {
        var username = $("#name").val();
        var pwd = $("#pwd").val();
        $.ajax({
           url : "${pageContext.request.contextPath }/testJson " ,
           type : "post" ,
            data : JSON.stringify({name:username ,pwd:pwd}) ,
            contentType : "application/json;charset=UTF-8",
            dataType : "json" ,
            success : function(data) {
                if (data != null) {
                    alert("您输入的用户名为: " + data.name + "密码为: " + data.pwd);
                }
            }
        })
    }
</script>
<html>
<head>
  <title>Title</title>
</head>
<body>
  <form>
      用 户 名 :<input type= "text" name="name" id="name" /><br />
      密 码 :<input type="text" name="pwd" id="pwd"/><br />
      <button type="button" onclick="clickJson()">点我!</button>
  </form>
</body>
</html>

5、编写Controller

//当注解使用RestController时,@ResponseBody不必添加 
//@RestController = @Controller + @ResponseBody

//@RestController  
@Controller
public class FirstController {
    

    @RequestMapping("/testJson")
    @ResponseBody
    public UserEntity  testJson(@RequestBody UserEntity userEntity){
        System.out.println(userEntity);
        return userEntity;
    }
}

在这里插入图片描述
方法中的@RequestBody 注解用于将前端请求体中的 JSON 格式数据绑定到形参 user 上,
@ResponseBody 注解用于直接返回 User 对象(当返回 POJO 对象时,会默认转换为 JSON 格
式数据进行响应)。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值