Jackson转换json大写_关于jackson转化json的原理_jackson序列化和反序列化Json

背景

web工程中,数据交互是不可避免的,相比xml,json是现在流行的数据交互。

在调试接口中,发现返回字段的大小写不是我所期望的,原本应该返回的nNum字段变成了nnum,这样就导致和前端约定的有出入了。

jackson

web工程中,比较流行的框架是springMVC+spring+mybatis。数据交互由springMVC完成,但是springMVC也不是自己序列化json的,它将这个工作交给了jackson。

jackson对object进行序列化的过程中确实存在key大写变小写的问题。看我娓娓道来。

序列化原理

这里只对jackson的序列化原理做阐述,其他的序列化工具不一定是相同的原理,不可套用。

众所周知,json的数据格式是,key:value的形式,现在的问题就出现在key的大小写这边。

下面我们对其进行一定的测试:

object中的field都有其对应的get,set方法,一般都会选择是IDE自动生成。如下图所示:

97a3f775f1cc5619c218ffe35fb83f8e.png

其运行的结果当然没有问题:

ada1756bf52d9caad9a9a941fcfc7c52.png

jackson在序列化的时候如何定义key呢?

jackson会获取field对应的get方法方法名,比如getXxx,然后进行将get进行截断,变成Xxx,最后将其小写,变成xxx。

如果我们将xxx改成xXx,但是没有更改其get方法,key仍然是xxx,并不是我们期望的xXx:

6eeae300b0092e307afd7212447f6acd.png

网上的很多博客基本都只提及大写转小写,其实不然,jackson只会将连续的大写转换成小写,如果中间断了,之后的大写字符也不会处理了,并且jackson是从开头检测的,如果开头就是小写,那么之后的大写字符也不会处理了。测试如下:

0f1358b50340fceba35024d7cf1ad658.png

c4787aa9a1d40ec2dc50d0526123e3d1.png

如何避免

正如网上的博客所说,你需要在field和其对应的get方法上加上对应的标签,然后jackson在序列化的时候就会以你的field名称为key:

3907fc20978ed5c9dc62f8f753951479.png

总结spring的序列化工作是由jackson完成(你也可以配置其他的序列化工具)

jackson序列化的key定义与field名称无关,反而和其get方法名称有关

jackson的大写转小写从开头检测,并且一定是连续的

jackson的这种序列化机制是可以避免的,这样可以以field名称作为key

jackson序列化和反序列化Json

jackson包提供了java对象与json相互转换的API。

jackson转换机制

Jackson要求java对象是一个POJO对象,即它是一个普通JavaBean对象。此外,如果字段是用private修饰的,则必须有getXXX()方法,否则字段用public修饰。

json常见格式如下

{"key1" : value,"key2" : [...],"key3" : {...}
}

jackson把JavaBean对象的每个字段映射为json的键,json键值由JavaBean的getXXX()方法确定。

json键值从形式上看,可以分为基本类型(字符串、数值)、数组、字典。当JavaBean的字段声明为基本类型时对应json的基本类型,当JavaBean声明为数组或链表时对应json的数组类型,当JavaBean声明为字典或对象时对应json的字典类型。

序列化

定义一个符合JavaBean规则的类

package com.weixia.Json;import java.util.ArrayList;
import java.util.HashMap;
import java.util.Map;public class Bean {private String name;private int[] stature;private Friend friend;private ArrayList<String> song;private Map<String,Integer> score = new HashMap<String,Integer>();public Bean(String name) {this.name = name;}public String getName() {return this.name;}public void setStature(int[] stature) {this.stature = stature;}public int[] getStature() {return this.stature;}public void setSong(ArrayList<String> song) {this.song = song;}public ArrayList<String> getSong() {return this.song;}public void setFriend(Friend friend) {this.friend = friend;}public Friend getFriend() {return this.friend;}public void addScore(String subject,Integer score) {this.score.put(subject, score);}public Map getScore() {return this.score;}
}class Friend {public String name;public int age;
}

将Bean对象序列化为json如下


package com.weixia.Json;import java.util.ArrayList;import com.fasterxml.jackson.databind.ObjectMapper;
import com.fasterxml.jackson.databind.SerializationFeature;
import com.fasterxml.jackson.annotation.JsonInclude.Include;public class App 
{public static void main( String[] args ) throws Exception{Bean bean = new Bean("Album");ObjectMapper mapper = new ObjectMapper();bean.setStature(new int[] {88,60,89});ArrayList<String> song = new ArrayList<String>();song.add("奇异恩典");song.add("东京的都");bean.setSong(song);Friend friend = new Friend();friend.name = "小明";friend.age = 24;bean.setFriend(friend);bean.addScore("Math", 100);bean.addScore("PE", 88);mapper.configure(SerializationFeature.INDENT_OUTPUT, true);	//格式化输出mapper.configure(SerializationFeature.ORDER_MAP_ENTRIES_BY_KEYS, true);	//键按自然顺序输出mapper.setSerializationInclusion(Include.NON_EMPTY);	//忽略POJO中属性为空的字段mapper.writeValue(System.out, bean);}
}

反序列化

json文件如下:

{"name": "weixia","age": 24,"stature":[89,66,89],"friend":{"name":"zhiye","age":24},"test":""
}

定义一个符合JaveBean规则的类

package com.weixia.Json;public class People {private String name;private int age;private Friend friend;private int[] stature;public String getName() {return this.name;}public int getAge() {return this.age;}public Friend getFriend() {return this.friend;}public int[] getStature() {return this.stature;}
}class Friend {public String name;public int age;
}

将json反序列化为java对象

package com.weixia.Json;import java.io.File;import com.fasterxml.jackson.databind.DeserializationFeature;
import com.fasterxml.jackson.databind.ObjectMapper;public class Json2Bean {public static void main(String[] args) throws Exception {ObjectMapper mapper = new ObjectMapper();mapper.configure(DeserializationFeature.FAIL_ON_UNKNOWN_PROPERTIES, false); //忽略未知的属性People people = mapper.readValue(new File("F:\\test.json"), People.class);System.out.println(people.getName());System.out.println(people.getAge());System.out.println(people.getFriend());int[] stature = people.getStature();for (int num : stature) {System.out.println(num);}}}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/555248.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

svn利用TortoiseSVN忽略文件或文件夹(目录)

忽略已经版本控制的文件 如果你不小心添加了一些应该被忽略的文件&#xff0c;你如何将它们从版本控制中去除而不会丢失它们&#xff1f;或许你有自己的IDE配置文件&#xff0c;不是项目的一部分&#xff0c;但将会花费很多时间使之按照自己的方式工作。 如果你还没有提交&am…

SpringMVC 参数绑定详解

概述 记得之前跟前端同事联调接口的时候&#xff0c;后端SpringMVC需要接收数组类型的参数&#xff0c;然后跟前端说需要传数组类型过来。后来前端童鞋传了数组&#xff0c;但是后端接收不成功&#xff0c;联调失败。那时候由于时间关系没有仔细研究这块&#xff0c;当时想了个…

java 连接远程服务器_java实现连接远程服务器并执行命令的基本原理

一、所需jar包需要借助Ganymed SSH的jar包: ganymed-ssh2-build210.jar二、实现原理Ganymed SSH-2 java在整个访问过程中担当SSH的客户端&#xff0c;由于Linux系统自带SSH服务&#xff0c;所以可以直接访问Linux系统并执行相关命令&#xff0c;而 Windows系统则需要首先安装S…

SpringMVC接收基本类型和包装类型

先看一个示例&#xff1a; 注意这两个参数都没有加RequestParam注解。 测试&#xff1a; 直接报错。即没有加RequestParam注解&#xff0c;基本数据类型参数是必填的。 再测试&#xff1a; 直接返回null&#xff0c;也就是说包装类型参数&#xff0c;没有加RequestParam注解&…

SpringMVC 【参数绑定详讲、默认支持参数类型、自定义参数绑定、RequestParam 注解】

SpringMVC 第四篇【参数绑定详讲、默认支持参数类型、自定义参数绑定、RequestParam 注解】 参数绑定 我们在 Controller 使用方法参数接收值&#xff0c;就是把 web 端的值给接收到 Controller 中处理&#xff0c;这个过程就叫做参数绑定… 默认支持的参数类型 从上面的用…

MySQL中 IS NULL、IS NOT NULL、不等于, 能用上索引吗?

MySQL的WHERE子句中包含 IS NULL、IS NOT NULL、! 这些条件时便不能使用索引查询&#xff0c;只能使用全表扫描。 告诉大家结论&#xff1a; MySQL中决定使不使用某个索引执行查询的依据就是成本够不够小&#xff0c;如果null值很多&#xff0c;还是会用到索引的。 自己做了个…

Java EE 企业网站_基于jsp的企业网站系统-JavaEE实现企业网站系统 - java项目源码...

基于jspservletpojomysql实现一个javaee/javaweb的企业网站系统, 该项目可用各类java课程设计大作业中, 企业网站系统的系统架构分为前后台两部分, 最终实现在线上进行企业网站系统各项功能,实现了诸如用户管理, 登录注册, 权限管理等功能, 并实现对各类企业网站系统相关的实体…

MySQL创建联合索引,字段的先后顺序,对查询的影响分析

文章目录前言最左匹配原则为什么会有最左前缀呢&#xff1f;联合索引的存储结构联合索引字段的先后顺序b树可以存储的数据条数总结前言 ​ 对于联合索引我们知道&#xff0c;在使用的时候有一个最左前缀的原则&#xff0c;除了这些呢&#xff0c;比如字段放置的位置&#xff0…

php oracle 操作 sql语句中能不能添加数组_如何在PHP中使用Oracle数据库_php

在php3.0以上版本中&#xff0c;php内置了几乎目前所有的数据库处理函数&#xff0c;包括oracle;在本文中我们通过一个实例来介绍了如何使用这些函数来操作Oracle数据库。PHP提供了2大类API(应用程序接口)来操作Oracle数据库。一个是标准的Oracle处理函数(ORA) 另一个是Oracle …

mysql where过滤条件中and连接的两个条件的顺序不必和建立的联合索引的字段顺序一致_mysql and 顺序_mysql执行过程以及顺序

mysql中and的判断顺序 select * from a join b on 条件一 and 条件二条件一和二都是判断 id 字段&#xff0c; 条件一和条件二哪个先执行&#xff1f; 解析器会自动选择最优的流程执行的 这两个都是平级条件&#xff0c;理论上是没有先后顺序的&#xff01; 没有顺序&#xff…

MySQL优化器_MySQL查询优化器

MySQL优化器 MySQL架构图 讲到MySQL&#xff0c;就绕不开他的架构图。MySQL是一个经典的C/S架构。服务器这边分两层&#xff1a;第一层是Server层&#xff0c;第二层是存储引擎。Server层处理主要的业务操作流程&#xff0c;但不关心具体的存储逻辑。存储逻辑由存储引擎层去…

MySQL性能优化(一)MySQL中SQL语句是如何执行的?

该篇章将开始整理MySQL的优化&#xff0c;不过开始之前&#xff0c;我们想了解清楚那就是MySQL是怎么执行的。 文章目录1.MySQL驱动2.应用系统数据库连接池3.MySQL数据库连接池4.SQL执行过程4.1.线程监听&#xff1a;监听网络请求中的SQL语句4.2.SQL接口&#xff1a;负责处理接…

2023_Spark_实验三十三:配置Standalone模式Spark3.4.2集群

实验目的&#xff1a;掌握Spark Standalone部署模式 实验方法&#xff1a;基于centos7部署Spark standalone模式集群 实验步骤&#xff1a; 一、下载spark软件 下载的时候下载与自己idea里对应版本的spark News | Apache Spark 选择任意一个下载即可 - spark 3.4.1 - spark …

MySQL性能优化(二)InnoDB之日志文件

文章目录1.MySQL日志记录文件1.1.回顾SQL语句的执行1.2.InnoDB内存结构&#xff1a;缓冲池1.3.记录日志&#xff1a;Undo和Redo1.3.1.Undo日志文件&#xff1a;记录数据修改前的值1.3.2.Redo日志文件&#xff1a;记录数据即将修改值1.3.3.Undo和Redo的区别&#xff08;记录、前…

php正则检查QQ,PHP 正则匹配手机号的QQ号

//匹配手机号码//$mode /\d{3}-\d{8}|\d{4}-\d{7}|\d{11}/;//不匹配以-开头的手机号码//$mode /^((?!-).)*\d{3}-\d{8}|^((?!-).)*\d{4}-\d{7}|^((?!-).)*\d{11}/;//不匹配以 / 开头或结束的手机号码$mode /^((?!\/).)*\d{3}-\d{8}((?!\/).)*$|^((?!\/).)*\d{4}-\d{7}…

java获取单击内容,java – 单击菜单链接时,获取元素不是可点击的异常

我想点击菜单链接但没有运气.它总是显示异常 –Exception in thread “main” org.openqa.selenium.WebDriverException:unknown error: Element is not clickable at point (64, 64). Otherelement would receive the click: <div style”position: absolute; left:0px; to…

MySQL性能优化(三)Buffer Pool实现原理

文章目录1.回顾缓冲池 Buffer Pool2.配置Buffer Pool的大小3.Buffer Pool&#xff1a;数据结构3.1.磁盘数据结构&#xff1a;数据页3.2.缓冲池数据结构&#xff1a;数据页(缓存页)3.3.缓存页对应的描述信息4.Buffer Pool&#xff1a;初始化5.Buffer Pool&#xff1a;free链表6.…

MySQL性能优化(四)redo log实现原理

文章目录1.redo log的作用2.redo log的结构2.1.redo log 记录2.2.redo log block2.3.redo log buffer3.redo log buffer 刷盘1.redo log的作用 首先我们都知道&#xff0c;执行增删改SQL语句的时候&#xff0c;都是针对一个表中的某些数据去执行的&#xff0c;此时的话&#x…

MySQL性能优化(五)undo log是如何实现MVCC的?

之前我们最开始的几篇文章就讲过&#xff0c;你除了写redolog日志还必须要写undo log日志&#xff0c;这个undo log日志是至关重要的&#xff0c;没有他&#xff0c;你根本都没办法回滚事务&#xff01; 1.事务 1.1.多线程并发执行多个事务 对于我们的业务系统去访问数据库而…

Linux中Shell脚本--awk的用法

语法格式&#xff1a;awk [选项] ‘指令’ 操作文件 常用选项&#xff1a;-F 指定分隔符&#xff0c;分隔符用""引起来 -v&#xff1a;varvalue在awk程序开始之前指定一个值valu给变量var&#xff0c;这些变量值用于awk程序的BEGIN快 -f&#xff1a;后面跟一个保存…