SpringMVC原理分析 | JSON、Jackson、FastJson

简介: SpringMVC原理分析 | JSON、Jackson、FastJson


JSON

JSON(JavaScriptObject Notation,JS对象简谱)是一种轻量级的数据交换格式。它基于 ECMAScript(European Computer Manufacturers Association,欧洲计算机协会制定的js规范)的一个子集,采用完全独立于编程语言的文本格式来存储和表示数据。简洁和清晰的层次结构使得 JSON 成为理想的数据交换语言。 易于人阅读和编写,同时也易于机器解析和生成,并有效地提升网络传输效率

特点:

  • 对象表示键值对,数据由逗号分隔
  • 花括号保存对象{}
  • 方括号保存数据[]

语法格式:

{"name":"wei_shuo"}
{"age":"3"}
{"sex":"男"}

JSON & JavaScript对象相互转换

JavaScript对象 ——> JSON对象
<script type="text/javascript">
        //编写一个JavaScript对象
        var user = {
            name: "wei_shuo",
            age: 18,
            sex: "男"
        };
        //将JavaScript对象转换为JSON对象
        let json = JSON.stringify(user);
        console.log(json);
    </script>
JSON对象 ——> JavaScript对象
<script type="text/javascript">
        //编写一个JavaScript对象
        var user = {
            name: "wei_shuo",
            age: 18,
            sex: "男"
        };
        //将JSON对象对象转换为JavaScript对象
        let obj = JSON.parse(json);
        console.log(obj)
    </script>

var、let、const | 全局、函数、块级作用域

函数作用域:var

块级作用域:let、const

  • 全局作用域:函数之外,使用var进行定义,在全局中都能使用的变量,称为全局变量,全局变量对应的作用域就是全局作用域
  • 函数作用域:函数之内,使用var进行定义,只能在该函数中使用的变量,称为函数变量(局部变量),局部变量对应的作用域就是函数作用域(局部作用域)
  • 块级作用域:ES6中,可以通过关键词let来定义变量,通过let定义的变量,只能在当前代码块(以 { } 为界限)中使用,对应的作用域为块级作用域

Jackson

Jackson 是用来解析 JSON 的框架是一种数据格式,用来在客户端和服务器之间,或系统组件之间交换数据

环境搭建

  • pom.xml中导包:导入Jackson和lambok的jar包
<dependencies>
  <dependency>
            <groupId>com.fasterxml.jackson.core</groupId>
            <artifactId>jackson-databind</artifactId>
            <version>2.14.0-rc3</version>
        </dependency>
        <dependency>
            <groupId>org.projectlombok</groupId>
            <artifactId>lombok</artifactId>
            <version>1.18.24</version>
   </dependency>
</dependencies>
  • 配置核心配置文件:web.xml
<?xml version="1.0" encoding="UTF-8"?>
<web-app xmlns="http://xmlns.jcp.org/xml/ns/javaee"
         xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
         xsi:schemaLocation="http://xmlns.jcp.org/xml/ns/javaee http://xmlns.jcp.org/xml/ns/javaee/web-app_4_0.xsd"
         version="4.0">
    <!--注册servlet-->
    <servlet>
        <servlet-name>SpringMVC</servlet-name>
        <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
        <!--通过初始化参数指定SpringMVC配置文件的位置,进行关联-->
        <init-param>
            <param-name>contextConfigLocation</param-name>
            <param-value>classpath:springmvc-servlet.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>
    <!--配置过滤器-->
    <filter>
        <filter-name>encoding</filter-name>
        <filter-class>org.springframework.web.filter.CharacterEncodingFilter</filter-class>
        <init-param>
            <param-name>encoding</param-name>
            <param-value>utf-8</param-value>
        </init-param>
    </filter>
    <filter-mapping>
        <filter-name>encoding</filter-name>
        <url-pattern>/</url-pattern>
    </filter-mapping>
</web-app>
  • 映射文件配置:springmvc-servlet.xml映射文件
<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
       xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
       xmlns:context="http://www.springframework.org/schema/context"
       xmlns:mvc="http://www.springframework.org/schema/mvc"
       xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd http://www.springframework.org/schema/context https://www.springframework.org/schema/context/spring-context.xsd http://www.springframework.org/schema/mvc https://www.springframework.org/schema/mvc/spring-mvc.xsd">
    <!--自动扫描指定的包,下面所有的注解交给IOC容器管理-->
    <context:component-scan base-package="com.wei.controller"/>
    <!--配置annotation-driven使:处理器映射器 和 处理器适配器 自动完成实例的注入-->
    <mvc:annotation-driven/>
    <!--视图解析器-->
    <bean class="org.springframework.web.servlet.view.InternalResourceViewResolver" id="internalResourceViewResolver">
        <!--前缀-->
        <property name="prefix" value="/WEB-INF/jsp/"/>
        <!--后缀-->
        <property name="suffix" value=".jsp"/>
    </bean>
</beans>
  • User类
@Data
@AllArgsConstructor
@NoArgsConstructor
public class User {
    private String name;
    private int age;
    private String sex;
}
  • UserController类
@Controller
public class UserController {
    //produces = "application/json;charset=utf-8" : 解决JSON对象乱码问题
    @RequestMapping(value = "/j1",produces = "application/json;charset=utf-8")
    @ResponseBody   //@ResponseBody不会通过视图解析器,会直接返回一个字符串
    public String json1() throws JsonProcessingException {
        //使用jackson包,创建ObjectMapper对象
        ObjectMapper mapper = new ObjectMapper();
        //创建对象
        User user = new User("wei_shuo",18,"男");
        String str = mapper.writeValueAsString(user);
        return str;
    }
}

JSON乱码解决

注解方式
//produces = "application/json;charset=utf-8" : 解决JSON对象乱码问题
    @RequestMapping(value = "/j1",produces = "application/json;charset=utf-8")
Spring配置方式
<!--JSON乱码解决-->
    <mvc:annotation-driven>
        <mvc:message-converters register-defaults="true">
            <bean class="org.springframework.http.converter.StringHttpMessageConverter">
                <constructor-arg value="UTF-8"/>
            </bean>
            <bean class="org.springframework.http.converter.json.MappingJackson2HttpMessageConverter">
                <property name="objectMapper">
                    <bean class="org.springframework.http.converter.json.Jackson2ObjectMapperFactoryBean">
                        <property name="failOnEmptyBeans" value="false"/>
                    </bean>
                </property>
            </bean>
        </mvc:message-converters>
    </mvc:annotation-driven>

返回JSON对象

  • @Controller:代码通过视图解析器
  • @RequestMapping:处理请求地址映射
  • @ResponseBody:@ResponseBody不会通过视图解析器,会直接返回一个字符串,同@Controller注解同时使用
  • @RestController:直接返回一个字符串
  • JSON返回普通对象
//代码通过视图解析器
@Controller
public class UserController {
    //produces = "application/json;charset=utf-8" : 解决JSON对象乱码问题
    @RequestMapping(value = "/j1")
    @ResponseBody   //@ResponseBody不会通过视图解析器,会直接返回一个字符串
    public String json1() throws JsonProcessingException {
        //使用jackson包,创建ObjectMapper对象
        ObjectMapper mapper = new ObjectMapper();
        //创建对象
        User user = new User("wei_shuo",18,"男");
        String str = mapper.writeValueAsString(user);
        return str;
    }
}
  • JSON返回集合对象
//直接返回一个字符串
@RestController
public class UserController {
    @RequestMapping("/j2")
    public String json2() throws JsonProcessingException {
        //使用jackson包,创建ObjectMapper对象
        ObjectMapper mapper = new ObjectMapper();
        //创建集合对象
        ArrayList<User> userList = new ArrayList<>();
        //创建对象
        User user1 = new User("wei_shuo",18,"男");
        User user2 = new User("tian_tain",19,"男");
        User user3 = new User("wu_wu",14,"男");
        User user4 = new User("qi_qi",25,"男");
        userList.add(user1);
        userList.add(user2);
        userList.add(user3);
        userList.add(user4);
        String str = mapper.writeValueAsString(userList);
        return str;
    }
}
  • JSON返回时间对象
@RestController
public class UserController {
    @RequestMapping("/j3")
    public String json3() throws JsonProcessingException {
        //使用jackson包,创建ObjectMapper对象
        ObjectMapper mapper = new ObjectMapper();
        //创建时间对象
        Date date = new Date();
        //自定义日期格式
        SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
        String format = sdf.format(date);
        String str = mapper.writeValueAsString(format);
        return str;         // "2022-11-19 18:08:43"
    }
}
  • 编写utils工具类返回时间对象(JsonUtils类)
package com.wei.utils;
import com.fasterxml.jackson.core.JsonProcessingException;
import com.fasterxml.jackson.databind.ObjectMapper;
import com.fasterxml.jackson.databind.SerializationFeature;
import java.text.SimpleDateFormat;
public class JsonUtils {
    public static String getJson(Object object){
        return getJson(object,"yyyy-MM-dd HH:mm:ss");
    }
    public static String getJson(Object object,String dateFormat){
        //使用jackson包,创建ObjectMapper对象
        ObjectMapper mapper = new ObjectMapper();
        //不使用时间戳的方式
        mapper.configure(SerializationFeature.WRITE_DATE_KEYS_AS_TIMESTAMPS,false);
        //自定义日期的格式
        SimpleDateFormat sdf = new SimpleDateFormat(dateFormat);
        mapper.setDateFormat(sdf);
        try {
            return mapper.writeValueAsString(object);
        } catch (JsonProcessingException e) {
            e.printStackTrace();
        }
        return null;
    }
}
  • UserController类
//直接返回一个字符串
@RestController
public class UserController {
    @RequestMapping("/j1")
    public String json2() throws JsonProcessingException {
        //创建集合对象
        ArrayList<User> userList = new ArrayList<>();
        //创建对象
        User user1 = new User("wei_shuo",18,"男");
        User user2 = new User("tian_tain",19,"男");
        User user3 = new User("wu_wu",14,"男");
        User user4 = new User("qi_qi",25,"男");
        userList.add(user1);
        userList.add(user2);
        userList.add(user3);
        userList.add(user4);
        return JsonUtils.getJson(userList);
    }
    @RequestMapping("/j2")
    public String json3() throws JsonProcessingException {
        //创建时间对象
        Date date = new Date();
        return JsonUtils.getJson(date,"yyyy-MM-dd HH:mm:ss");
    }
}

FastJson

Fastjson是一个Java语言编写的高性能功能完善的JSON库。它采用一种“假定有序快速匹配”的算法,把JSON Parse的性能提升到极致,是目前Java语言中最快的JSON库。Fastjson接口简单易用,已经被广泛使用在缓存序列化、协议交互、Web输出、Android客户端等多种应用场景

环境搭建

  • 导入pom.xml依赖
<dependencies>
    <dependency>
        <groupId>com.alibaba</groupId>
        <artifactId>fastjson</artifactId>
        <version>2.0.18</version>
    </dependency>
</dependencies>
  • 使用FastJson
@RestController
public class UserController {
    @RequestMapping("/j1")
    public String json1() throws JsonProcessingException {
        //创建集合对象
        ArrayList<User> userList = new ArrayList<>();
        //创建对象
        User user1 = new User("wei_shuo",18,"男");
        User user2 = new User("tian_tain",19,"男");
        User user3 = new User("wu_wu",14,"男");
        User user4 = new User("qi_qi",25,"男");
        userList.add(user1);
        userList.add(user2);
        userList.add(user3);
        userList.add(user4);
        String s = JSON.toJSONString(userList);
        return s;
    }
}

Java <——> Json相互转换

Java对象——>Json字符串 JSON.toJSONString(Object,object);
Json字符串——>Java对象 JSON.parseObject(String str, Class objectClass);
Java对象——>Json对象 JSON.parseObject(String str, Class objectClass);
Java对象——>Json对象 JSON.toJSON(Object javaObject);
Json对象——>Java对象 JSON.toJavaObject(JSON json, Class clazz);
@RestController
public class UserController {
    @RequestMapping("/j1")
    public String json1() throws JsonProcessingException {
        //创建集合对象
        ArrayList<User> userList = new ArrayList<>();
        //创建对象
        User user1 = new User("wei_shuo", 18, "男");
        User user2 = new User("tian_tain", 19, "男");
        User user3 = new User("wu_wu", 14, "男");
        User user4 = new User("qi_qi", 25, "男");
        userList.add(user1);
        userList.add(user2);
        userList.add(user3);
        userList.add(user4);
        System.out.println("Java对象——>Json字符串");
        String str1 = JSON.toJSONString(userList);
        System.out.println("JSON字符串:" + str1);
        System.out.println("=================");
        String str2 = JSON.toJSONString(user1);
        System.out.println("JSON字符串:" + str2);
        System.out.println("=================");
        System.out.println("Json字符串——>Java对象");
        User Json_TO_Java1 = JSON.parseObject(str2, User.class);
        System.out.println("Java对象:" + Json_TO_Java1);
        System.out.println("Java对象——>Json对象");
        JSONObject jsonObject = (JSONObject) JSON.toJSON(user1);
        System.out.println("Json对象:" + jsonObject.getString("name"));
        System.out.println("Json对象——>Java对象");
        User Json_TO_Java2 = JSON.toJavaObject(jsonObject, User.class);
        System.out.println("Java对象:" + Json_TO_Java2);
        return "Hello";
    }
}
/*
输出结果:
Java对象——>Json字符串
JSON字符串:[{"age":18,"name":"wei_shuo","sex":"男"},{"age":19,"name":"tian_tain","sex":"男"},{"age":14,"name":"wu_wu","sex":"男"},{"age":25,"name":"qi_qi","sex":"男"}]
=================
JSON字符串:{"age":18,"name":"wei_shuo","sex":"男"}
=================
Json字符串——>Java对象
Java对象:User(name=wei_shuo, age=18, sex=男)
Java对象——>Json对象
Json对象:wei_shuo
Json对象——>Java对象
Java对象:User(name=wei_shuo, age=18, sex=男)
*/

🌼 结语:创作不易,如果觉得博主的文章赏心悦目,还请——点赞👍收藏⭐️评论📝


目录
相关文章
|
6月前
|
前端开发 Java 微服务
《深入理解Spring》:Spring、Spring MVC与Spring Boot的深度解析
Spring Framework是Java生态的基石,提供IoC、AOP等核心功能;Spring MVC基于其构建,实现Web层MVC架构;Spring Boot则通过自动配置和内嵌服务器,极大简化了开发与部署。三者层层演进,Spring Boot并非替代,而是对前者的高效封装与增强,适用于微服务与快速开发,而深入理解Spring Framework有助于更好驾驭整体技术栈。
|
6月前
|
JSON Java Go
【GoGin】(2)数据解析和绑定:结构体分析,包括JSON解析、form解析、URL解析,区分绑定的Bind方法
bind或bindXXX函数(后文中我们统一都叫bind函数)的作用就是将,以方便后续业务逻辑的处理。
421 3
|
8月前
|
JSON API 数据安全/隐私保护
深度分析淘宝卖家订单详情API接口,用json返回数据
淘宝卖家订单详情API(taobao.trade.fullinfo.get)是淘宝开放平台提供的重要接口,用于获取单个订单的完整信息,包括订单状态、买家信息、商品明细、支付与物流信息等,支撑订单管理、ERP对接及售后处理。需通过appkey、appsecret和session认证,并遵守调用频率与数据权限限制。本文详解其使用方法并附Python调用示例。
|
9月前
|
前端开发 Java API
Spring Cloud Gateway Server Web MVC报错“Unsupported transfer encoding: chunked”解决
本文解析了Spring Cloud Gateway中出现“Unsupported transfer encoding: chunked”错误的原因,指出该问题源于Feign依赖的HTTP客户端与服务端的`chunked`传输编码不兼容,并提供了具体的解决方案。通过规范Feign客户端接口的返回类型,可有效避免该异常,提升系统兼容性与稳定性。
632 0
|
9月前
|
SQL Java 数据库连接
Spring、SpringMVC 与 MyBatis 核心知识点解析
我梳理的这些内容,涵盖了 Spring、SpringMVC 和 MyBatis 的核心知识点。 在 Spring 中,我了解到 IOC 是控制反转,把对象控制权交容器;DI 是依赖注入,有三种实现方式。Bean 有五种作用域,单例 bean 的线程安全问题及自动装配方式也清晰了。事务基于数据库和 AOP,有失效场景和七种传播行为。AOP 是面向切面编程,动态代理有 JDK 和 CGLIB 两种。 SpringMVC 的 11 步执行流程我烂熟于心,还有那些常用注解的用法。 MyBatis 里,#{} 和 ${} 的区别很关键,获取主键、处理字段与属性名不匹配的方法也掌握了。多表查询、动态
263 0
|
9月前
|
JSON 前端开发 Java
第05课:Spring Boot中的MVC支持
第05课:Spring Boot中的MVC支持
365 0
|
JSON 前端开发 Java
微服务——SpringBoot使用归纳——Spring Boot中的MVC支持——@RequestBody
`@RequestBody` 是 Spring 框架中的注解,用于将 HTTP 请求体中的 JSON 数据自动映射为 Java 对象。例如,前端通过 POST 请求发送包含 `username` 和 `password` 的 JSON 数据,后端可通过带有 `@RequestBody` 注解的方法参数接收并处理。此注解适用于传递复杂对象的场景,简化了数据解析过程。与表单提交不同,它主要用于接收 JSON 格式的实体数据。
1381 0
|
前端开发 Java 测试技术
微服务——SpringBoot使用归纳——Spring Boot中的MVC支持——@RequestParam
本文介绍了 `@RequestParam` 注解的使用方法及其与 `@PathVariable` 的区别。`@RequestParam` 用于从请求中获取参数值(如 GET 请求的 URL 参数或 POST 请求的表单数据),而 `@PathVariable` 用于从 URL 模板中提取参数。文章通过示例代码详细说明了 `@RequestParam` 的常用属性,如 `required` 和 `defaultValue`,并展示了如何用实体类封装大量表单参数以简化处理流程。最后,结合 Postman 测试工具验证了接口的功能。
730 0
微服务——SpringBoot使用归纳——Spring Boot中的MVC支持——@RequestParam
|
前端开发 Java 微服务
微服务——SpringBoot使用归纳——Spring Boot中的MVC支持——@PathVariable
`@PathVariable` 是 Spring Boot 中用于从 URL 中提取参数的注解,支持 RESTful 风格接口开发。例如,通过 `@GetMapping(&quot;/user/{id}&quot;)` 可以将 URL 中的 `{id}` 参数自动映射到方法参数中。若参数名不一致,可通过 `@PathVariable(&quot;自定义名&quot;)` 指定绑定关系。此外,还支持多参数占位符,如 `/user/{id}/{name}`,分别映射到方法中的多个参数。运行项目后,访问指定 URL 即可验证参数是否正确接收。
822 0
|
JSON 前端开发 Java
微服务——SpringBoot使用归纳——Spring Boot中的MVC支持——@RequestMapping
@RequestMapping 是 Spring MVC 中用于请求地址映射的注解,可作用于类或方法上。类级别定义控制器父路径,方法级别进一步指定处理逻辑。常用属性包括 value(请求地址)、method(请求类型,如 GET/POST 等,默认 GET)和 produces(返回内容类型)。例如:`@RequestMapping(value = &quot;/test&quot;, produces = &quot;application/json; charset=UTF-8&quot;)`。此外,针对不同请求方式还有简化注解,如 @GetMapping、@PostMapping 等。
729 0