源代碼:
1
|
public <T> T convertValue(Object fromValue, TypeReference<?> toValueTypeRef) throws IllegalArgumentException { return (T) _convert(fromValue, _typeFactory.constructType(toValueTypeRef)); } |
該方法用于用jackson將bean轉(zhuǎn)換為map
例子:
1
|
List<SObject> sObjects = new ObjectMapper().convertValue(map.get( "list" ), new TypeReference<List<SObject>>() { }); |
微服務(wù)中從其他服務(wù)獲取過來的對(duì)象,如果從Object強(qiáng)轉(zhuǎn)為自定義的類型會(huì)報(bào)錯(cuò),利用ObjectMapper轉(zhuǎn)換。
1
2
3
4
5
6
|
ObjectMapper mapper = new ObjectMapper(); DefaultResponse defaultResponse = proxy.getData(); List<Resource> resources = (<Resource>) defaultResponse.getData(); //這里的場(chǎng)景是:data是一個(gè)Object類型的,但是它其實(shí)是一個(gè)List<Resouce>,想把List中的每個(gè)對(duì)象分別轉(zhuǎn)成可用的對(duì)象 for ( int i = 0 ; i < serviceDateResources.size(); i++) { Resource resource = mapper.convertValue(resources.get(i), Resource. class ); //經(jīng)過這步處理,resource就是可用的類型了,如果不轉(zhuǎn)化會(huì)報(bào)錯(cuò) } |
在轉(zhuǎn)換過程中有些屬性被設(shè)置為空,這樣就不需要轉(zhuǎn)化
處理方法:
在需要轉(zhuǎn)化的實(shí)體類商添加如下注解
1
2
3
4
5
|
@JsonInclude (Include.NON_NULL) @JsonInclude (Include.Include.ALWAYS) 默認(rèn) @JsonInclude (Include.NON_DEFAULT) 屬性為默認(rèn)值不序列化 @JsonInclude (Include.NON_EMPTY) 屬性為 空(“”) 或者為 NULL 都不序列化 @JsonInclude (Include.NON_NULL) 屬性為NULL 不序列化 |
jackson objectMapper json字符串、對(duì)象bean、map、數(shù)組list互相轉(zhuǎn)換常用的方法列舉:
1
|
ObjectMapper mapper = new ObjectMapper(); |
1.對(duì)象轉(zhuǎn)json字符串
1
2
|
User user= new User(); String userJson=mapper.writeValueAsString(user); |
2.Map轉(zhuǎn)json字符串
1
2
|
Map map= new HashMap(); String json=mapper.writeValueAsString(map); |
3.數(shù)組list轉(zhuǎn)json字符串
1
2
|
Student[] stuArr = {student1, student3}; String jsonfromArr = mapper.writeValueAsString(stuArr); |
4.json字符串轉(zhuǎn)對(duì)象
1
2
|
String expected = "{\"name\":\"Test\"}" ; User user = mapper.readValue(expected, User. class ); |
5.json字符串轉(zhuǎn)Map
1
2
|
String expected = "{\"name\":\"Test\"}" ; Map userMap = mapper.readValue(expected, Map. class ); |
6.json字符串轉(zhuǎn)對(duì)象數(shù)組List
1
2
3
|
String expected= "[{\"a\":12},{\"b\":23},{\"name\":\"Ryan\"}]" ; CollectionType listType = mapper.getTypeFactory().constructCollectionType(ArrayList. class , User. class ); List<User> userList = mapper.readValue(expected, listType); |
7.json字符串轉(zhuǎn)Map數(shù)組List<Map<String,Object>>
1
2
3
|
String expected= "[{\"a\":12},{\"b\":23},{\"name\":\"Ryan\"}]" ; CollectionType listType = mapper.getTypeFactory().constructCollectionType(ArrayList. class , Map. class ); List<Map<String,Object>> userMapList = mapper.readValue(expected, listType); |
8.jackson默認(rèn)將對(duì)象轉(zhuǎn)換為LinkedHashMap:
1
2
|
String expected = "[{\"name\":\"Ryan\"},{\"name\":\"Test\"},{\"name\":\"Leslie\"}]" ; ArrayList arrayList = mapper.readValue(expected, ArrayList. class ); |
9.json字符串與list或map互轉(zhuǎn)的方法
1
2
3
4
5
6
7
8
9
10
11
12
|
ObjectMapper objectMapper = new ObjectMapper(); //遇到date按照這種格式轉(zhuǎn)換 SimpleDateFormat fmt = new SimpleDateFormat( "yyyy-MM-dd HH:mm:ss" ); objectMapper.setDateFormat(fmt); String preference = "{name:'侯勇'}" ; //json字符串轉(zhuǎn)map Map<String, String> preferenceMap = new HashMap<String, String>(); preferenceMap = objectMapper.readValue(preference, preferenceMap.getClass()); //map轉(zhuǎn)json字符串 String result=objectMapper.writeValueAsString(preferenceMap); |
10.bean轉(zhuǎn)換為map
1
2
3
4
5
|
List<Map<String,String>> returnList= new ArrayList<Map<String,String>>(); List<Menu> menuList=menuDAOImpl.findByParentId(parentId); ObjectMapper mapper = new ObjectMapper(); //用jackson將bean轉(zhuǎn)換為map returnList=mapper.convertValue(menuList, new TypeReference<List<Map<String, String>>>(){}); |
objectMapper.convertValue() 報(bào)錯(cuò)
報(bào)錯(cuò)信息如下:
com.fasterxml.jackson.databind.exc.InvalidDefinitionException: Cannot construct instance of java.time.LocalDateTime (no Creators, like default constructor, exist): cannot deserialize from Object value (no delegate- or property-based Creator) at [Source: UNKNOWN; line: -1, column: -1] (through reference chain: net.too1.tplus.user.user.entity.User[“createTime”])
根據(jù)以上報(bào)錯(cuò)得知, 是java.time.LocalDateTime類型的原因. ObjectMapper 不能對(duì)LocalDateTime 序列化. 加上以下注解即可解決
1
2
|
@JsonDeserialize (using = LocalDateTimeDeserializer. class ) @JsonSerialize (using = LocalDateTimeSerializer. class ) |
1
2
3
4
|
@ApiModelProperty (value = "創(chuàng)建時(shí)間" ) @JsonDeserialize (using = LocalDateTimeDeserializer. class ) @JsonSerialize (using = LocalDateTimeSerializer. class ) private LocalDateTime createTime; |
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持服務(wù)器之家。
原文鏈接:https://blog.csdn.net/weixin_39778417/article/details/103304940