将JSON数据转换成JAVA的实体类
思路:首先将JSON格式的数据转换成JSONObject,然后将JSONObject转换成Java的实体类(其中类属性包括List等类型)
Java实体类:
SearchFilter 类

1 public class SearchFilter {
2 private String groupOp;
3
4 private List<SearchRule> rules;
5
6 public String getGroupOp() {
7 return groupOp;
8 }
9
10 public void setGroupOp(String groupOp) {
11 this.groupOp = groupOp;
12 }
13
14 public List<SearchRule> getRules() {
15 return rules;
16 }
17
18 public void setRules(List<SearchRule> rules) {
19 this.rules = rules;
20 }

SearchRule 类:

1 public class SearchRule {
2 private String field;
3 private String op;
4 private String data;
5 public String getField() {
6 return field;
7 }
8 public void setField(String field) {
9 this.field = field;
10 }
11 public String getOp() {
12 return op;
13 }
14 public void setOp(String op) {
15 this.op = op;
16 }
17 public String getData() {
18 return data;
19 }
20 public void setData(String data) {
21 this.data = data;
22 }
23
24
25 }

1 //导入的package
2 import com.fasterxml.jackson.databind.ObjectMapper;
3 import net.sf.json.JSONArray;
4 import net.sf.json.JSONObject;
解析JSon格式字符串的方法

1 public SearchFilter jsonToSearchFilter(String filters) {
2 SearchFilter searchFilter = null;
3 try {
4 JSONObject jsonobject = JSONObject.fromObject(filters);//将json格式的字符串转换成JSONObject 对象
5 JSONArray array = jsonobject.getJSONArray("rules"); //如果json格式的字符串里含有数组格式的属性,将其转换成JSONArray,以方便后面转换成对应的实体
6 List<SearchRule> rules = new ArrayList<SearchRule>();
7 for (int i = 0; i < array.size(); i++) {
8 JSONObject object = (JSONObject) array.get(i); //将array中的数据进行逐条转换
9 SearchRule rule = (SearchRule) JSONObject.toBean(object, SearchRule.class); //通过JSONObject.toBean()方法进行对象间的转换
10 rules.add(rule);
11 }
12 String groupOp = jsonobject.getString("groupOp"); //简单的直接获取值
13 searchFilter = new SearchFilter(); //对SearchFilter对象进行组装
14 searchFilter.setGroupOp(groupOp);
15 searchFilter.setRules(rules);
16 } catch (Exception e) {
17 System.out.println("filters=" + filters.toString() + ".json转换成实体类出错");
18 e.printStackTrace();
19 }
20 return searchFilter;
21 }

这里只进行了SearchFilter类中list<SearchRule>rule属性的对象转换,因为它是一个SearchRule对象数组,需要单独拿出来进行json转换成对象,如果直接对filter进行 SearchFilter进行实体转换会报错。如果对象中不含有list,array,map等集合,可以像8-9行一样进行对象转换。
测试:

1 public static void main(String[] args) {
2 UserMgmtController con = new UserMgmtController();
3 String filters="{\"groupOp\": \"OR\",\"rules\": [{\"field\": \"realname\",\"op\": \"eq\","+
4 "\"data\": \"1234\"},{\"field\": \"cityCode\",\"op\": \"ne\",\"data\": \"5678\"}]}";
5 SearchFilter searchFilter =con.jsonToSearchFilter(filters);
6 System.out.println("gop="+searchFilter.getGroupOp()+" rules.size="+searchFilter.getRules().size());
7 }
结果:gop=OR rules.size=2

将java对象转换成json格式:

1 //将Object 对象转换成 json
2 public String objectToJson(Object obj) {
3 ObjectMapper mapper = new ObjectMapper();
4 // Convert object to JSON string
5 String jsonStr = null;
6 try {
7 jsonStr = mapper.writeValueAsString(obj);
8 } catch (IOException e) {
9 log.error(obj + "entity 轉換成 json出錯", e);
10 e.printStackTrace();
11 System.out.println("entity 轉換成 json出錯");
12 }
13 return jsonStr;
14 }

将Object 转换成json字符串时,默认使用用是的驼峰方式,如果不想使用驼峰则可以增加红色部分设置,带下划线的也可以原样输出:

1 public String objectToJson(Object obj){
2 ObjectMapper mapper = new ObjectMapper();
3 String json =null;
4 try {
5 PropertyNamingStrategy.PascalCaseStrategy pp = new PropertyNamingStrategy.PascalCaseStrategy();
6 mapper.setPropertyNamingStrategy(pp);
7 json = mapper.writeValueAsString(obj);
8 } catch (JsonProcessingException e) {
9 log.error("json对象转换失败",e);
10 e.printStackTrace();
11 }
12 return json;
13 }

结果:
"UpLoadDateTime":"2017-09-25 10:51:41","OrganizationId":"B3EA5A4D-7C60-4C21-AF09-494890467C34" ,"Test_Code":""
将JSON数据转换成JAVA的实体类的更多相关文章
- 利用JAVA反射机制将JSON数据转换成JAVA对象
net.sf.json.JSONObject为我们提供了toBean方法用来转换为JAVA对象, 功能更为强大, 这里借鉴采用JDK的反射机制, 作为简单的辅助工具使用, 有些数据类型需要进行转 ...
- c# json数据解析——将字符串json格式数据转换成对象或实体类
网络中数据传输经常是xml或者json,现在做的一个项目之前调其他系统接口都是返回的xml格式,刚刚遇到一个返回json格式数据的接口,通过例子由易到难总结一下处理过程,希望能帮到和我一样开始不会的朋 ...
- 【转】C#中将JSon数据转换成实体类,将实体类转换成Json
http://wo13145219.iteye.com/blog/2022667 http://json2csharp.chahuo.com/ using System; using System.C ...
- c#实例化继承类,必须对被继承类的程序集做引用 .net core Redis分布式缓存客户端实现逻辑分析及示例demo 数据库笔记之索引和事务 centos 7下安装python 3.6笔记 你大波哥~ C#开源框架(转载) JSON C# Class Generator ---由json字符串生成C#实体类的工具
c#实例化继承类,必须对被继承类的程序集做引用 0x00 问题 类型“Model.NewModel”在未被引用的程序集中定义.必须添加对程序集“Model, Version=1.0.0.0, Cu ...
- 高速创建和mysql表相应的java domain实体类
今天创建了一个表有十几个字段,创建完之后必定要写一个与之相应的java domain实体类. 这不是反复的工作吗?为什么不先把这个表的全部的字段查出来,然后放到linux环境下,用sed工具在每一行的 ...
- 将行数据转换成Java(POJO)对象
工作中经常会遇到将行数据转换成Java(POJO)对象的场景,其中关于字段校验和类型转换的处理繁琐而冗余,对于有代码洁癖的人着实不能忍.这里分享下自己封装的工具代码,也许能够帮助你更简单地完成此类任务 ...
- 4.使用Jackson将Json数据转换成实体数据
Jar下载地址:http://jackson.codehaus.org/ 注意: 一.类中的属性名称一定要和Json数据的属性名称一致(大写和小写敏感),类之间的嵌套关系也应该和Json数据的嵌套关系 ...
- JSONArray数据转换成java List
1.后台接收json数组转成封装实体类的List: package no.integrasco.ingentia.news.qaedition; public class Person { priva ...
- JSON C# Class Generator ---由json字符串生成C#实体类的工具
json作为互联网上轻量便捷的数据传输格式,越来越受到重视.但在服务器端编程过程中,我们常常希望能通过智能提示来提高编码效率.JSON C# Class Generator 能将json格式所表示的J ...
随机推荐
- MySQL架构之 主从+ProxySQL实现读写分离
准备服务器: docker run -d --privileged -v `pwd`/mysql_data:/data -p 3001:3306 --name mysql5-master --host ...
- 验证Textbox的字符长度
private void textBox1_KeyPress(object sender, System.Windows.Forms.KeyPressEventArgs e) { ) { //Indi ...
- Spring------生命周期
Spring------生命周期 转:https://blog.csdn.net/qq_42112846/article/details/81368862 如图所示: 一下就是对上图的解释: Spri ...
- OpenStack Trove组件WSGI和RPC调用流程(参考调用的整个过程)
参考博文:https://blog.csdn.net/bill_xiang_/article/details/72909927
- 63.1拓展之纯 CSS 创作一个摇摇晃晃的 loader
效果地址:https://scrimba.com/c/cqKv4VCR HTML code: <div class="loader"> <span>Load ...
- final关键字特点
一.final关键字修饰的类 无法被继承(即不能有子类) 二.final关键字修饰的方法不能被重写 三.final关键字修饰的变量成为常量(即不允许被修改) 开发中经常使用
- leetcode155
public class MinStack { Stack<int> S = new Stack<int>(); /** initialize your data struct ...
- Mysql 和 SQLServer 使用SQL差异比较
查询前100条数据 #mysql ; #sqlserver * from table_name ; 从数据库.表 定位表 #mysql写法:库名.表名 select password from Inf ...
- 第二篇*2、Python字符串格式化
1.字符串格式化 Python的字符串格式化有两种方式: 百分号方式.format方式 1)百分号方式 %[(name)][flags][width].[precision]typecode (nam ...
- Oracle,cast函数
cast(要转换的值 AS 转换的类型): 问题:' ' as FSubBillNo 若用此法 oracle 默认字段类型为char型 且字段长度度为输入空格的长度,会导致字符串 ...