Java如何实现实体类转Map、Map转实体类

 更新时间:2021年08月11日 09:47:13   作者:知识追求者  
这篇文章主要介绍了Java 实现实体类转Map、Map转实体类的操作,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教

实体类转Map、Map转实体类

1、创建entity(User.java)

package com.jeff.entity;
public class User {
 private String userName;
 private String password;
 private Integer age;
 public User() {
  super();
 }
 public User(String userName, String password, Integer age) {
  super();
  this.userName = userName;
  this.password = password;
  this.age = age;
 }
 public String getUserName() {
  return userName;
 }
 public void setUserName(String userName) {
  this.userName = userName;
 }
 public String getPassword() {
  return password;
 }
 public void setPassword(String password) {
  this.password = password;
 }
 public Integer getAge() {
  return age;
 }
 public void setAge(Integer age) {
  this.age = age;
 }
 @Override
 public String toString() {
  return "User [userName=" + userName + ", password=" + password + ", age=" + age + "]";
 }
}

2、创建utils(EntityUtils.java)

package com.jeff.utils;
import java.lang.reflect.Field;
import java.util.HashMap;
import java.util.Map;
public class EntityUtils {
 /**
  * 
  * @description: 实体类转Map
  * @author: Jeff
  * @date: 2019年10月29日
  * @param object
  * @return
  */
 public static Map<String, Object> entityToMap(Object object) {
  Map<String, Object> map = new HashMap<>();
  for (Field field : object.getClass().getDeclaredFields()) {
   try {
    boolean flag = field.isAccessible();
    field.setAccessible(true);
    Object o = field.get(object);
    map.put(field.getName(), o);
    field.setAccessible(flag);
   } catch (Exception e) {
    e.printStackTrace();
   }
  }
  return map;
 }
 /**
  * 
  * @description: Map转实体类
  * @author: Jeff
  * @date: 2019年10月29日
  * @param <T>
  * @param map    需要初始化的数据,key字段必须与实体类的成员名字一样,否则赋值为空
  * @param entity 需要转化成的实体类
  * @return
  */
 public static <T> T mapToEntity(Map<String, Object> map, Class<T> entity) {
  T t = null;
  try {
   t = entity.newInstance();
   for (Field field : entity.getDeclaredFields()) {
    if (map.containsKey(field.getName())) {
     boolean flag = field.isAccessible();
     field.setAccessible(true);
     Object object = map.get(field.getName());
     if (object != null && field.getType().isAssignableFrom(object.getClass())) {
      field.set(t, object);
     }
     field.setAccessible(flag);
    }
   }
   return t;
  } catch (InstantiationException e) {
   e.printStackTrace();
  } catch (IllegalAccessException e) {
   e.printStackTrace();
  }
  return t;
 }
}

3、创建Map转实体类(TestCopyObj3.java)

package com.jeff;
import java.util.HashMap;
import java.util.Map;
import com.jeff.entity.User;
import com.jeff.utils.EntityUtils;
public class TestCopyObj3 {
 public static void main(String[] args) throws Exception {
  Map<String, Object> map = new HashMap<String, Object>();
  map.put("userName", "Jeff");
  map.put("password", "123456");
  map.put("age", 18);
  System.out.println("Map对象:" + map);
  User user = EntityUtils.mapToEntity(map, User.class);
  System.out.println("User对象:" + user);
 }
}

4、控制台输出结果

在这里插入图片描述

5、创建实体类转Map(TestCopyObj4.java)

package com.jeff;
import java.util.Map;
import com.jeff.entity.User;
import com.jeff.utils.EntityUtils;
public class TestCopyObj4 {
	public static void main(String[] args) throws Exception {
		User user = new User("Jeff", "123456", 18);
		System.out.println("User对象:" + user);
		Map<String, Object> map = EntityUtils.entityToMap(user);
		System.out.println("Map对象:" + map);
	}
}

6、控制台输出结果

在这里插入图片描述

Map转实体类或List数组

因为做项目,需要取出复杂的map里的value转为实体类对象和List,在博客里找了很久没有找到合适的方法,于是只能默默探索。。。

map里包含了实体类,list数组,还有普通的key-value,取出我们想要的数据呢?直接取我是取不出来,后来想先转json,在从json里去出对象和list,然后就这么干,废话少说,撸代码!!!

1.先添加maven依赖,这里用alibaba的

<!--alibaba json  -->
<dependency>
    <groupId>com.alibaba</groupId>
    <artifactId>fastjson</artifactId>
    <version>1.2.46</version>
</dependency>

2.自己写的一个JsonUtil工具类

import com.alibaba.fastjson.JSON;
import com.alibaba.fastjson.JSONArray;
import com.alibaba.fastjson.JSONObject;
import java.util.List;
import java.util.Map;
public class JsonUtil<T>{
    
    public static JSONObject mapToJson(Map<String, Object> map) {
        String data = JSON.toJSONString(map);
        return JSON.parseObject(data);
    }
    /**
     * map中取key对应的value
     * @param map
     * @param key
     * @return
     */
    public String mapToString(Map<String, Object> map, String key) {
        JSONObject jsonObject = mapToJson(map);
        return jsonObject.getString(key);
    }
    /**
     * map中取类对象
     * @param map
     * @param clazz
     * @param key
     * @param <T>
     * @return
     */
    public static <T> T mapToObject(Map<String, Object> map, Class<T> clazz, String key) {
        T t = null;
        JSONObject jsonObject = mapToJson(map);
        JSONObject object = jsonObject.getJSONObject(key);
        t = object.toJavaObject(clazz);
        return t;
    }
    /**
     * map中取list
     * @param map
     * @param clazz
     * @param key
     * @return
     */
    public  List<T> mapToList(Map<String, Object> map, Class<T> clazz, String key) {
        List<T> t = null;
        JSONObject jsonObject = mapToJson(map);
        JSONArray array = jsonObject.getJSONArray(key);
        t = array.toJavaList(clazz);
        return t;
    }
}

3.用 postman 发送数据到后台

4.后台接收代码

    @RequestMapping(value = "/subjects/subject", method = {RequestMethod.POST})
    public Result addSubject(@RequestBody Map<String, Object> map) {
        //使用json
        JsonUtil jsonUtil = new JsonUtil();
        //获取Subject对象
        Subject subject = jsonUtil.mapToObject(map, Subject.class, "subject");
        //获取List数组
        List<Progress> progressList = jsonUtil.mapToList(map, Progress.class, "progress");
        //获取key对应的值
        String specid = jsonUtil.mapToString(map, "specid");
        //打印输出
        System.out.println(subject);
        for(Progress progress : progressList) {
            System.out.println(progress);
        }
        System.out.println(specid);
        return null;
    }

5.后台输出

到此成功从map里取出对象,list,和key-value

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

相关文章

  • Java通过MyBatis框架对MySQL数据进行增删查改的基本方法

    Java通过MyBatis框架对MySQL数据进行增删查改的基本方法

    MyBatis框架由Java的JDBC API进一步封装而来,在操作数据库方面效果拔群,接下来我们就一起来看看Java通过MyBatis框架对MySQL数据进行增删查改的基本方法:
    2016-06-06
  • 谷歌二维码引擎com.google.zxing二维码生成与解析

    谷歌二维码引擎com.google.zxing二维码生成与解析

    这篇文章主要给大家介绍了关于谷歌二维码引擎com.google.zxing二维码生成与解析的相关资料,zxing是google开源的二维码生成和解析工具,需要的朋友可以参考下
    2023-07-07
  • 使用Jenkins来构建GIT+Maven项目的方法步骤

    使用Jenkins来构建GIT+Maven项目的方法步骤

    这篇文章主要介绍了使用Jenkins来构建GIT+Maven项目,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2021-01-01
  • 学习Java九大内置对象

    学习Java九大内置对象

    学习Java九大内置对象,从现在开始,希望大家可以通过这篇文章可以真正的理解Java九大内置对象,感兴趣的朋友可以参考一下
    2016-05-05
  • springboot 排除redis的自动配置操作

    springboot 排除redis的自动配置操作

    这篇文章主要介绍了springboot 排除redis的自动配置操作,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2021-07-07
  • Springboot详解如何整合使用Thymeleaf

    Springboot详解如何整合使用Thymeleaf

    这篇文章主要分享了Spring Boot整合使用Thymeleaf,Thymeleaf是新一代的Java模板引擎,类似于Velocity、FreeMarker等传统引擎,关于其更多相关内容,需要的小伙伴可以参考一下
    2022-06-06
  • SpringBoot增量/瘦身部署jar包的方式

    SpringBoot增量/瘦身部署jar包的方式

    SpringBoot 项目的部署一般采用全量jar 包方式部署相关项目,如果我们对相关的Contrller层进行相关业务调整就需要重新编译全量jar 包太麻烦了,所以本文给大家介绍了使用SpringBoot 的增量/瘦身部署方式,需要的朋友可以参考下
    2024-01-01
  • MapReduce中ArrayWritable 使用指南

    MapReduce中ArrayWritable 使用指南

    MapReduce是一种编程模型,用于大规模数据集的并行运算。概念"Map(映射)"和"Reduce(归约)"和他们的主要思想,都是从函数式编程语言里借来的,还有从矢量编程语言里借来的特性。他极大地方便了编程人员在不会分布式并行编程的情况下,将自己的程序运行在分布式系统上。
    2014-08-08
  • 浅谈对象数组或list排序及Collections排序原理

    浅谈对象数组或list排序及Collections排序原理

    下面小编就为大家带来一篇浅谈对象数组或list排序及Collections排序原理。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2016-09-09
  • Java排序之Comparable和Comparator比较器详解

    Java排序之Comparable和Comparator比较器详解

    这篇文章主要介绍了Java排序之Comparable和Comparator比较器详解,Comparable<T>是内部比较器,Comparator<T>是外部比较器,最推荐使用Comparator<T>接口排序,Comparator提供静态方法很方便,推荐使用,需要的朋友可以参考下
    2024-01-01

最新评论