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,一经查实,立即删除!

相关文章

groovy+mysql数据库_使用Groovy连接到MySQL

我正在尝试使用MAC OS 10.10.5 Yosemite上的以下Groovy代码连接到MySQL数据库import groovy.sql.Sqltry{def dbURL jdbc:mysql://localhost:3306/sakiladef dbUserName rootdef dbPassword Orange27def dbDriver com.mysql.jdbc.Driverlog.info(Good)def db Sql.newInstan…

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

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

java打印两个小人_[原创]Java画小人与阶梯问题的解答

package test;/**#Python源代码:#By:Cat73 QQ 1901803382#2014年7月22日19:33:12#画图函数 width:台阶的宽度(至少为4) hight:台阶的高度(至少为4) count:台阶的数量(至少为3)def paint(width, hight, count):for i in range(1, count):other(width, hight, count, i)#画出最后…

SpringMVC 参数绑定详解

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

java httpcomponents_java – 如何使用Apache httpcomponents从NHttpRequ...

我正在使用Apache httpcomponents实现一个彗星式(延迟响应)http服务器.我的代码与http://hc.apache.org/httpcomponents-core-ga/examples.html的“基本非阻塞HTTP服务器”示例非常相似我使用DefaultServerIOEventDispatch和DefaultListeningIOReactor来分派请求,就像在示例代码…

java servlet是单例吗_关于java:为什么apache servlet是单例?

本问题已经有最佳答案&#xff0c;请猛点这里访问。HttpServletRequest request;HttpServletResponse response;public void doGet(HttpServletRequest request , HttpServlet response){this.request request;this.response response;}如果此servlet一次收到多个请求会发生什…

OkHttp的作用_为什么要使用OkHttp?(笔记)

OkHttp的作用 OkHttp is an HTTP client。 如果是HTTP的方式想得到数据&#xff0c;就需要我们在页面上输入网址&#xff0c;如果网址没有问题&#xff0c;就有可能返回对应的String字符串&#xff0c;如果这个地址是返回字符串的话。 OkHttp是在idea代码中&#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保留字不能作为字段名使用_Table字段不能设为关键字range,range在mysql中是分区,是mysql的关键字

mysql 中Table字段不能设为关键字range&#xff0c;range在mysql中是分区,是mysql的关键字 在设计MySQL字段的时候&#xff0c;无意中使用InOut这个名称作为字段名称&#xff0c;结果前端提交后就是没有写入数据库&#xff01;但后端没有任何提示&#xff0c;跟踪mySQL日志&…

java+的数组分割符_Java:使用分隔符连接基元数组

小编典典这是我想出的。有几种方法可以执行此操作&#xff0c;它们取决于您使用的工具。使用StringUtils和ArrayUtils来自CommonLang&#xff1a;int[] arr new int[] {1, 2, 3, 4, 5, 6, 7};String result StringUtils.join(ArrayUtils.toObject(arr), " - ");您不…

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…

php开发电商项目的技术,[项目实战] php电商开发基本功课程 电商后台实战开发视频教程 共6章...

1-1需求分析.mp41-2 数据表建立.mp41-3 前期准备.mp42-1 验证码制作.mp42-2 数据库操作函数封装.mp42-3 登录验证.mp42-4 自动登录功能.mp42-5 后台用户信息管理.mp42-6 分页页码代码封装.mp42-7 后台用户信息分页页码制.mp43-1 添加分类信息.mp43-2 显示分类信息.mp43-3 修改分…

MySQL优化器_MySQL查询优化器

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

php取商,PHP获取百度关键词排名

PHP获取百度关键词排名$k$_GET[‘k’] ? $_GET[‘k’] : ‘蓝普网络‘;$u$_GET[‘u’] ? $_GET[‘u’] : ‘www.wbphp.cn’;$rn’50’;$url “https://www.baidu.com/s?ieutf-8&wd”.$k.”&rn”.$rn;$ch curl_init();curl_setopt($ch, CURLOPT_URL, $url);curl_se…