jackson解析json 和jsonarray 常见错误处理

jackson解析json

ObjectMapper mapper = new ObjectMapper();
HttpPrintResponse response = mapper.readValue(json, HttpPrintResponse.class);

jackson 解析jsonarray

TypeReference<List<HttpPrintResponseItem>> type = new TypeReference<List<HttpPrintResponseItem>>() {};
List<HttpPrintResponseItem> list = mapper.readValue(json, type);

jackson 解析,因字段不存在产生测错误处理

错误信息

com.fasterxml.jackson.databind.exc.UnrecognizedPropertyException: Unrecognized field "result" (class com.jasper.HttpPrintResponse), not marked as ignorable (3 known properties: , "data", "returnCode", "info"])
 at [Source: java.io.StringReader@7f234f85; line: 1, column: 15] (through reference chain: com.jasper.HttpPrintResponse["result"])
	at com.fasterxml.jackson.databind.exc.UnrecognizedPropertyException.from(UnrecognizedPropertyException.java:79)
	at com.fasterxml.jackson.databind.DeserializationContext.reportUnknownProperty(DeserializationContext.java:579)
	at com.fasterxml.jackson.databind.deser.std.StdDeserializer.handleUnknownProperty(StdDeserializer.java:672)
	at com.fasterxml.jackson.databind.deser.BeanDeserializerBase.handleUnknownProperty(BeanDeserializerBase.java:906)
	at com.fasterxml.jackson.databind.deser.BeanDeserializer.deserializeFromObject(BeanDeserializer.java:328)
	at com.fasterxml.jackson.databind.deser.BeanDeserializer.deserialize(BeanDeserializer.java:121)
	at com.fasterxml.jackson.databind.ObjectMapper._readMapAndClose(ObjectMapper.java:2793)
	at com.fasterxml.jackson.databind.ObjectMapper.readValue(ObjectMapper.java:1943)
	at com.yianju.printer.PrinterClient.execute(PrinterClient.java:156)
	at com.yianju.printer.PrinterClient.access$0(PrinterClient.java:136)
	at com.yianju.printer.PrinterClient$1.run(PrinterClient.java:119)
	at java.util.TimerThread.mainLoop(Timer.java:555)
	at java.util.TimerThread.run(Timer.java:505)

解决办法

ObjectMapper mapper = new ObjectMapper();
mapper.configure(DeserializationFeature.FAIL_ON_UNKNOWN_PROPERTIES, false);

jackson 时间处理的错误处理

异常信息

com.fasterxml.jackson.databind.exc.InvalidFormatException: Can not construct instance of java.util.Date from String value '2019-10-21 14:45:20': not a valid representation (error: Failed to parse Date value '2019-10-21 14:45:20': Can not parse date "2019-10-21 14:45:20": not compatible with any of standard forms ("yyyy-MM-dd'T'HH:mm:ss.SSSZ", "yyyy-MM-dd'T'HH:mm:ss.SSS'Z'", "EEE, dd MMM yyyy HH:mm:ss zzz", "yyyy-MM-dd"))
 at [Source: java.io.StringReader@48957e9d; line: 1, column: 1890] (through reference chain: com.jasper.HttpPrintResponseItem["createTime"])
	at com.fasterxml.jackson.databind.exc.InvalidFormatException.from(InvalidFormatException.java:55)
	at com.fasterxml.jackson.databind.DeserializationContext.weirdStringException(DeserializationContext.java:650)
	at com.fasterxml.jackson.databind.deser.std.StdDeserializer._parseDate(StdDeserializer.java:577)
	at com.fasterxml.jackson.databind.deser.std.DateDeserializers$DateBasedDeserializer._parseDate(DateDeserializers.java:142)
	at com.fasterxml.jackson.databind.deser.std.DateDeserializers$DateDeserializer.deserialize(DateDeserializers.java:231)
	at com.fasterxml.jackson.databind.deser.std.DateDeserializers$DateDeserializer.deserialize(DateDeserializers.java:214)
	at com.fasterxml.jackson.databind.deser.SettableBeanProperty.deserialize(SettableBeanProperty.java:375)
	at com.fasterxml.jackson.databind.deser.impl.MethodProperty.deserializeAndSet(MethodProperty.java:98)
	at com.fasterxml.jackson.databind.deser.BeanDeserializer.deserializeFromObject(BeanDeserializer.java:308)
	at com.fasterxml.jackson.databind.deser.BeanDeserializer.deserialize(BeanDeserializer.java:121)
	at com.fasterxml.jackson.databind.deser.std.CollectionDeserializer.deserialize(CollectionDeserializer.java:226)
	at com.fasterxml.jackson.databind.deser.std.CollectionDeserializer.deserialize(CollectionDeserializer.java:203)
	at com.fasterxml.jackson.databind.deser.std.CollectionDeserializer.deserialize(CollectionDeserializer.java:23)
	at com.fasterxml.jackson.databind.ObjectMapper._readMapAndClose(ObjectMapper.java:2793)
	at com.fasterxml.jackson.databind.ObjectMapper.readValue(ObjectMapper.java:1950)
	at com.yianju.printer.PrinterClient.execute(PrinterClient.java:163)
	at com.yianju.printer.PrinterClient.access$0(PrinterClient.java:136)
	at com.yianju.printer.PrinterClient$1.run(PrinterClient.java:119)
	at java.util.TimerThread.mainLoop(Timer.java:555)
	at java.util.TimerThread.run(Timer.java:505)

解决办法

DateFormat fmt = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");  
ObjectMapper mapper = new ObjectMapper();
mapper.setDateFormat(fmt);
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值