zoukankan      html  css  js  c++  java
  • SpringMVC-JSON

    JSON

    1. JSON基础

    1. 前后端分离

    • 后端: 部署后端, 提供接口, 提供数据

    • 前端: 独立部署, 负责渲染后端的数据

    • JSON负责将前后端连接起来

    2. JSON概述

    • JSON(JavaScript Object Notation, JS 对象标记) 是一种轻量级的数据交换格式,目前使用特别广泛。
    • 采用完全独立于编程语言的文本格式来存储和表示数据。
    • 简洁和清晰的层次结构使得 JSON 成为理想的数据交换语言。
    • 易于人阅读和编写,同时也易于机器解析和生成,并有效地提升网络传输效率。

    在 JavaScript 语言中,一切都是对象。因此,任何JavaScript 支持的类型都可以通过 JSON 来表示,例如字符串、数字、对象、数组等。看看他的要求和语法格式:

    • 对象表示为键值对,数据由逗号分隔
    • 花括号保存对象
    • 方括号保存数组

    JSON 键值对是用来保存 JavaScript 对象的一种方式,和 JavaScript 对象的写法也大同小异,键/值对组合中的键名写在前面并用双引号 "" 包裹,使用冒号 : 分隔,然后紧接着值

    2. JSON和JavaScript对象互相转换

    JavaScript转JSON, 用JSON.stringify()

    <!DOCTYPE html>
    <html lang="en">
    <head>
        <meta charset="UTF-8">
        <title>Title</title>
    
        <script type="text/javascript">
    
            //编写一个JavaScript对象
            let user = {
                name : "wang_sky",
                age : 3,
                sex: "男"
            };
    
            //将js对象转换为json对象
            let json = JSON.stringify(user);
    
            console.log(json);
    
        </script>
    
    </head>
    <body>
    
    
    
    </body>
    </html>
    

    JSON转JavaScript, 用JSON.parse()

    <!DOCTYPE html>
    <html lang="en">
    <head>
        <meta charset="UTF-8">
        <title>Title</title>
    
        <script type="text/javascript">
    
            //编写一个JavaScript对象
            let user = {
                name : "wang_sky",
                age : 3,
                sex: "男"
            };
    
            //将js对象转换为json对象
            let json = JSON.stringify(user);
    
            console.log(json);
            console.log(user);
    
            //将json对象转换为JavaScript对象
            let parse = JSON.parse(json);
            console.log(parse);
    
        </script>
    
    </head>
    <body>
    
    
    
    </body>
    </html>
    

    3. Jackson

    1. 导入依赖

    <!-- https://mvnrepository.com/artifact/com.fasterxml.jackson.core/jackson-databind -->
    <dependency>
        <groupId>com.fasterxml.jackson.core</groupId>
        <artifactId>jackson-databind</artifactId>
        <version>2.11.2</version>
    </dependency>
    

    2. 编写controller

    package com.wang.controller;
    
    import com.fasterxml.jackson.core.JsonProcessingException;
    import com.fasterxml.jackson.databind.ObjectMapper;
    import com.wang.pojo.User;
    import org.springframework.stereotype.Controller;
    import org.springframework.web.bind.annotation.RequestMapping;
    import org.springframework.web.bind.annotation.ResponseBody;
    
    @Controller
    public class UserController {
    
        //@ResponseBody: 它就不会走视图解析器, 会直接返回一个字符串到当前页面!
        @ResponseBody
        @RequestMapping("/j1")
        public String json1() throws JsonProcessingException {
    
            //jackson, ObjectMapper
            ObjectMapper mapper = new ObjectMapper();
    
            //创建一个对象
            User user = new User("wang_sky_1", 3, "男");
    
            String string = mapper.writeValueAsString(user);
    
            return string;
        }
    
    }
    

    结果为

    {"name":"wang_sky_1","age":3,"sex":"?"}

    3. 解决乱码

    发现出现了乱码问题,我们需要设置一下他的编码格式为utf-8,以及它返回的类型;

    通过@RequestMaping的produces属性来实现,修改下代码

    //produces:指定响应体返回类型和编码
    @RequestMapping(value = "/j1",produces = "application/json;charset=utf-8")
    

    4. 代码优化

    1. 统一解决乱码

    在spring配置文件中配置如下

    <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>
    

    2. 两个注解

    • @RestController: 在类上, 表示这个controller不走视图解析器, 直接返回字符串
    • @ResponseBody: 在方法上, 与@RestController作用一致
    • 以上两个注解用来做前后端分离传递JSON

    3. 集合

    @ResponseBody
    @RequestMapping(value = "/j2")
    public String json2() throws JsonProcessingException {
        ObjectMapper mapper = new ObjectMapper();
        ArrayList<User> users = new ArrayList<>();
        User user1 = new User("wang_sky_1", 3, "男");
        User user2 = new User("wang_sky_2", 4, "男");
        User user3 = new User("wang_sky_3", 5, "男");
        User user4 = new User("wang_sky_4", 6, "男");
        users.add(user1);
        users.add(user2);
        users.add(user3);
        users.add(user4);
        String user = mapper.writeValueAsString(users);
        return user;
    }
    

    结果

    [{"name":"wang_sky_1","age":3,"sex":"男"},{"name":"wang_sky_2","age":4,"sex":"男"},{"name":"wang_sky_3","age":5,"sex":"男"},{"name":"wang_sky_4","age":6,"sex":"男"}]

    4. 时间

    1. 使用java自定义日期格式
    @RequestMapping(value = "/j3")
    public String json3() throws JsonProcessingException {
        ObjectMapper mapper = new ObjectMapper();
    
        Date date = new Date();
    
        //自定义日期格式
        SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
    
        return mapper.writeValueAsString(sdf.format(date));
    }
    
    2. 使用ObjectMapper格式化输出
    @RequestMapping(value = "/j4")
    public String json4() throws JsonProcessingException {
        ObjectMapper mapper = new ObjectMapper();
    
        //使用ObjectMapper格式化输出, 关闭时间戳
        mapper.configure(SerializationFeature.WRITE_DATES_AS_TIMESTAMPS, false);
    
        //自定义日期格式
        SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
    
        mapper.setDateFormat(sdf);
    
        Date date = new Date();
    
        return mapper.writeValueAsString(date);
    }
    
    3. 利用工具类
    1. 工具类

    注意: 此处要注意两点:

    • 写成静态方法方便调用
    • 方法重载时, 可以从方法签名全的倒着写, 缺省的参数在重载的方法中设定默认值!
    package com.wang.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");
        }
    
        //这里写成静态方法, 方便调用(不用new 对象)
        public static String getJson(Object object, String dateFormat) {
            ObjectMapper mapper = new ObjectMapper();
            //使用ObjectMapper格式化输出, 关闭时间戳
            mapper.configure(SerializationFeature.WRITE_DATES_AS_TIMESTAMPS, false);
            //自定义日期格式
            SimpleDateFormat sdf = new SimpleDateFormat(dateFormat);
            mapper.setDateFormat(sdf);
    
            try {
                return mapper.writeValueAsString(object);
            } catch (JsonProcessingException e) {
                e.printStackTrace();
                return null;
            }
    
        }
    }
    
    
    1. 调用
    @RequestMapping("/j5")
    public String json5() {
        String dateFormat = "yyyy-MM-dd HH:mm:ss";
        return JsonUtils.getJson(new Date(), dateFormat);
    }
    

    5. JSON总结

    • 导入jackson包

    • 配置解决乱码问题

    • 返回JSON: 使用@RestController(类上)或者@RequestBody(方法上)

    • new一个ObjectMapper()

    • 利用new出的mapper, 调用writeValueAsString(对象)

    • 即可得到由对象转换为的JSON

    4. FastJSON

    1. 导入依赖

    <!-- https://mvnrepository.com/artifact/com.alibaba/fastjson -->
    <dependency>
        <groupId>com.alibaba</groupId>
        <artifactId>fastjson</artifactId>
        <version>1.2.73</version>
    </dependency>
    

    2. fastjson 三个主要的类:

    1. JSONObject 代表 json 对象

    • JSONObject实现了Map接口, 猜想 JSONObject底层操作是由Map实现的。
    • JSONObject对应json对象,通过各种形式的get()方法可以获取json对象中的数据,也可利用诸如size(),isEmpty()等方法获取"键:值"对的个数和判断是否为空。其本质是通过实现Map接口并调用接口中的方法完成的。

    2. JSONArray 代表 json 对象数组

    • 内部是有List接口中的方法来完成操作的。

    3. JSON代表 JSONObject和JSONArray的转化

    • JSON类源码分析与使用
    • 仔细观察这些方法,主要是实现json对象,json对象数组,javabean对象,json字符串之间的相互转化。

    3. 测试

    @RequestMapping(value = "/j6")
    public String json6() throws JsonProcessingException {
        ArrayList<User> users = new ArrayList<>();
        User user1 = new User("wang_sky_1", 3, "男");
        User user2 = new User("wang_sky_2", 4, "男");
        User user3 = new User("wang_sky_3", 5, "男");
        User user4 = new User("wang_sky_4", 6, "男");
        users.add(user1);
        users.add(user2);
        users.add(user3);
        users.add(user4);
        return JSON.toJSONString(users);
    }
    
  • 相关阅读:
    jdk.jre.jvm 三者之间的关系?
    SQL7
    SQL6
    sql题
    sql题
    sql
    简说SQL题
    递归算法
    JAVA的简单描述
    第一篇技术博客
  • 原文地址:https://www.cnblogs.com/wang-sky/p/13638401.html
Copyright © 2011-2022 走看看