后端程序员的前后端交互核心-JSON

简介: 后端程序员的前后端交互核心-JSON

关于JSON

1 JSON概述

JSON(JavaScript Object Notation, JS 对象标记) 是一种轻量级的数据交换格式。

它基于 ECMAScript (W3C制定的JS规范)的一个子集,采用完全独立于编程语言的文本格式来存储和表示数据。

简洁和清晰的层次结构使得 JSON 成为理想的数据交换语言。

易于人阅读和编写,同时也易于机器解析和生成,并有效地提升网络传输效率。

2 JSON语法

  • [] 表示json数组
  • {} 表示json对象
  • “” 表示是属性名或字符串类型的值
  • : json数据都是由key和value组成
  • , json中的数据与数据之间的分隔

举例:

JSON对象

{name:“宋柠檬”,age:30,gender :“女”,birthday:“2023-03-28”}

JSON数组

[{name:“宋柠檬”,age:30,gender:“女”,birthday:“2023-03-28”}, {name:“李柠檬”,age:25,sex:“男”,birthday:“2023-03-27”}]

3 Json技术

Json技术: JSON字符串的生成和解析

  • FastJson 阿里里巴巴
  • JackSon github
  • Gson google公司

4 JackSon

  • 创建ObjectMapper对象
  • ObjectMapper mapper = new ObjectMapper();
  • 将json字符串生成Java对象
  • mapper.readValue(json字符串,类对象)

将json数组字符串生成Java对象

mapper.readValue(json字符串,数组[].class);

先将字符串生成Java数组,再将数组转换成集合

mapper.readValue(json字符串,new TypeReference<ArrayList>(){});

  • mapper.readValue(json, mapper.getTypeFactory().constructCollectionType(List.class, User.class));
  • 将Java对象解析成json字符串
  • mapper.writeValueAsString(对象|集合);

注意:

  • 日期类型转换的时候需要加上注解
  • @JsonFormat(pattern= “yyyy-MM-dd HH:mm:ss”,timezone = “GMT+8”)
  • 如果字段名与字符串中的key不一致。
  • @JsonProperty(“address”)
  • 忽略实体类中的属性(不进行json转换)
  • @JsonIgnore
public class TestJackson {
    //将java对象转换成json字符串
    @Test
    public void test01() throws JsonProcessingException {
        Emp emp = new Emp(4399,"前端","开发",7777,new Date(),4000d,0d,20,null);
        //将java对象转换成json字符串
        ObjectMapper mapper = new ObjectMapper();
        String json = mapper.writeValueAsString(emp);
        System.out.println(json);
    }
    //将java对象集合转换成json字符串
    @Test
    public void test02() throws JsonProcessingException {
        List<Emp> empList = new ArrayList<>();
        for (int i = 0; i < 5; i++) {
            Emp emp = new Emp(4399+i,"前端"+i,"开发"+i,7777,new Date(),4000d,0d,20,null);
            empList.add(emp);
        }
        //将java对象集合转换成json字符串
        ObjectMapper mapper = new ObjectMapper();
        String json = mapper.writeValueAsString(empList);
        System.out.println(json);
    }

    //将json格式的字符串转成java对象
    @Test
    public void test03() throws IOException {
        String json = "{\"empno\":4399,\"ename\":\"前端\",\"job1\":\"开发\",\"mgr\":7777,\"hiredate\":1634007374014,\"sal\":4000.0,\"comm\":0.0,\"deptno\":20,\"image\":null}";
        //将json格式的字符串转成java对象
        ObjectMapper mapper = new ObjectMapper();
        Emp emp = mapper.readValue(json, Emp.class);
        System.out.println(emp);
    }

    //将json数组格式的字符串转成java对象集合
    @Test
    public void test04() throws IOException {
        String json = "[{\"empno\":4399,\"ename\":\"前端0\",\"job\":\"开发0\",\"mgr\":7777,\"hiredate\":1634007490425,\"sal\":4000.0,\"comm\":0.0,\"deptno\":20,\"image\":null},{\"empno\":4400,\"ename\":\"前端1\",\"job\":\"开发1\",\"mgr\":7777,\"hiredate\":1634007490425,\"sal\":4000.0,\"comm\":0.0,\"deptno\":20,\"image\":null},{\"empno\":4401,\"ename\":\"前端2\",\"job\":\"开发2\",\"mgr\":7777,\"hiredate\":1634007490425,\"sal\":4000.0,\"comm\":0.0,\"deptno\":20,\"image\":null},{\"empno\":4402,\"ename\":\"前端3\",\"job\":\"开发3\",\"mgr\":7777,\"hiredate\":1634007490425,\"sal\":4000.0,\"comm\":0.0,\"deptno\":20,\"image\":null},{\"empno\":4403,\"ename\":\"前端4\",\"job\":\"开发4\",\"mgr\":7777,\"hiredate\":1634007490425,\"sal\":4000.0,\"comm\":0.0,\"deptno\":20,\"image\":null}]";
        //将json数组格式的字符串转成java对象集合
        ObjectMapper mapper = new ObjectMapper();
        //方式1:
        //Emp[] emps = mapper.readValue(json, Emp[].class);
        //将数组转换成List集合
        //List<Emp> empList = Arrays.asList(emps);
        //empList.forEach(System.out::println);

        //方式2:
        List<Emp> empList = mapper.readValue(json, mapper.getTypeFactory().constructCollectionType(List.class, Emp.class));
        empList.forEach(System.out::println);
    }
}
目录
相关文章
|
1月前
|
前端开发 API UED
Python后端与前端交互新纪元:AJAX、Fetch API联手,打造极致用户体验!
Python后端与前端交互新纪元:AJAX、Fetch API联手,打造极致用户体验!
70 2
|
2月前
|
前端开发 JavaScript API
解锁高效应用构建:Vuex与后端交互的前端状态同步策略,让数据流动如行云流水,紧跟前端开发的热点趋势
【8月更文挑战第27天】本文深入探讨了Vue框架下的前端状态管理库Vuex与后端服务交互时的状态同步策略。通过剖析Vuex的核心机制——状态(State)、变异(Mutation)、动作(Action)及模块(Module),文章展示了如何优雅地将后端数据加载并更新至前端状态中。特别地,借助示例代码解释了Action处理API调用、Mutation更新状态的过程,并介绍了如何通过模块化和命名空间提高状态管理的准确性和时效性。此外,还讨论了组件如何利用`mapState`和`mapActions`简化状态访问与操作的方法。遵循这些策略,开发者可以在构建复杂应用时显著提升性能与用户体验。
42 0
|
18天前
|
前端开发 Java
学习SpringMVC,建立连接,请求,响应 SpringBoot初学,如何前后端交互(后端版)?最简单的能通过网址访问的后端服务器代码举例
文章介绍了如何使用SpringBoot创建简单的后端服务器来处理HTTP请求,包括建立连接、编写Controller处理请求,并返回响应给前端或网址。
37 0
学习SpringMVC,建立连接,请求,响应 SpringBoot初学,如何前后端交互(后端版)?最简单的能通过网址访问的后端服务器代码举例
|
7天前
|
存储 JSON 前端开发
JSON与现代Web开发:数据交互的最佳选择
JSON(JavaScript Object Notation)是一种轻量级的数据交换格式,易于人阅读和编写,同时也便于机器解析和生成。它以文本格式存储数据,常用于Web应用中的数据传输,尤其是在客户端和服务器之间。
22 0
|
2月前
|
XML 存储 前端开发
后端程序员的前后端交互核心-Ajax
后端程序员的前后端交互核心-Ajax
49 6
后端程序员的前后端交互核心-Ajax
|
2月前
|
JavaScript 前端开发 程序员
后端程序员的前端必备-jQuery核心学习笔记
后端程序员的前端必备-jQuery核心学习笔记
52 13
|
2月前
|
前端开发 JavaScript 程序员
后端程序员的前端捷径-超级容易上手使用的前端框架layUI(上)
后端程序员的前端捷径-超级容易上手使用的前端框架layUI
47 10
|
2月前
|
前端开发 JavaScript 程序员
后端程序员的前端捷径-超级容易上手使用的前端框架layUI(下)
后端程序员的前端捷径-超级容易上手使用的前端框架layUI
68 9
|
2月前
|
XML JSON 前端开发
JSON与AJAX:网页交互的利器
JSON与AJAX:网页交互的利器
33 0
|
10天前
|
缓存 Java 数据库
后端技术探索:从基础架构到高效开发的实践之路
【10月更文挑战第7天】 在现代软件开发中,后端技术是支撑应用运行的核心。本文将探讨如何从后端的基础架构出发,通过一系列高效的开发实践,提升系统的性能与可靠性。我们将深入分析后端框架的选择、数据库设计、接口开发等关键领域,并提供实用的代码示例和优化策略,帮助开发者构建更稳定、高效的后端系统。通过这篇文章,读者将获得关于后端开发的全面理解和实践指导,从而更好地应对复杂项目需求。
35 0

热门文章

最新文章