Java如何實現(xiàn)實體類轉(zhuǎn)Map、Map轉(zhuǎn)實體類
實體類轉(zhuǎn)Map、Map轉(zhuǎn)實體類
1、創(chuàng)建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、創(chuàng)建utils(EntityUtils.java)
package com.jeff.utils;
import java.lang.reflect.Field;
import java.util.HashMap;
import java.util.Map;
public class EntityUtils {
/**
*
* @description: 實體類轉(zhuǎn)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轉(zhuǎn)實體類
* @author: Jeff
* @date: 2019年10月29日
* @param <T>
* @param map 需要初始化的數(shù)據(jù),key字段必須與實體類的成員名字一樣,否則賦值為空
* @param entity 需要轉(zhuǎn)化成的實體類
* @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、創(chuàng)建Map轉(zhuǎn)實體類(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、控制臺輸出結(jié)果

5、創(chuàng)建實體類轉(zhuǎn)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、控制臺輸出結(jié)果

Map轉(zhuǎn)實體類或List數(shù)組
因為做項目,需要取出復(fù)雜的map里的value轉(zhuǎn)為實體類對象和List,在博客里找了很久沒有找到合適的方法,于是只能默默探索。。。
map里包含了實體類,list數(shù)組,還有普通的key-value,取出我們想要的數(shù)據(jù)呢?直接取我是取不出來,后來想先轉(zhuǎn)json,在從json里去出對象和list,然后就這么干,廢話少說,擼代碼?。。?/p>
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對應(yīng)的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 發(fā)送數(shù)據(jù)到后臺

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數(shù)組
List<Progress> progressList = jsonUtil.mapToList(map, Progress.class, "progress");
//獲取key對應(yīng)的值
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
以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關(guān)文章
java基于AES對稱加密算法實現(xiàn)的加密與解密功能示例
這篇文章主要介紹了java基于AES對稱加密算法實現(xiàn)的加密與解密功能,結(jié)合完整實例形式分析了AES對稱加密算法的定義與使用技巧,需要的朋友可以參考下2017-01-01
Spring中ApplicationContext的拓展功能詳解
這篇文章主要介紹了Spring中ApplicationContext的拓展功能詳解,相對于BeanFactory來說,ApplicationContext除了提供BeanFactory的所有功能外,還有一些其他的功能,主要包括國際化支持、資源訪問、事件傳遞,需要的朋友可以參考下2024-01-01
基于rabbitmq延遲插件實現(xiàn)分布式延遲任務(wù)
這篇文章主要介紹了基于rabbitmq延遲插件實現(xiàn)分布式延遲任務(wù),今天我們講解延遲隊列的實現(xiàn)方式,而延遲隊列有很多種實現(xiàn)方式,今天就每種實現(xiàn)方式給大家大概介紹下,感興趣的朋友一起看看吧2022-01-01
springboot使用mybatis一對多的關(guān)聯(lián)查詢問題記錄
這篇文章主要介紹了springboot使用mybatis一對多的關(guān)聯(lián)查詢問題記錄,剛好最近有個需求需要做到關(guān)聯(lián)的查詢,時間也算充足,所以用sql來寫,于是踩了很久坑,終于跳出來了,小小記錄一下2022-01-01

