-
Notifications
You must be signed in to change notification settings - Fork 115
com.microsoft.bot.schema.Serialization ObjectMapper is unable to serialize Java8 Date/Time with newest jackson. #1454
Comments
@kreigiron My first thought is that the additional modules are registered by way of inclusion in the POM's. For date and time, this is specifically the jackson-datatype-jsr310 module. Of note also is that we've only fully tested on Java8. Though I do believe I've run it on 11 without issue. That particular "illegal reflective access" is a 9+ warning. Have you tried this with JDK 8? |
@tracyboehrer actually the JDK8Module is part of jackson-datatype-jsr310 so yes, we need to include that artifact, but it seems that we may need to manually add the JDK8Module into the mapper otherwise it won't register (at least that did not work for me). I tried with JDK8 but due to GC constraints we need to run on java 13+, my current workaround is to downgrade jackson when running on that jvm version, but if we try to use jackson provided within newest Spring boot (2.12+) it won't work. Thanks. |
@kreigiron Let us dig into it. With 8, those modules are just available after a call to objectMapper.findAndRegisterModules();. |
We have also run into this issue.
We get the following exception
Downgrading jackson or java is not an option for us unfortunately. Have you got any updates on this issue, or some suggested workarounds? |
@tracyboehrer we did a little experimentation trying to correct the issue. We made it go away by instantiating
This might be a superficial solution, as |
Thanks all. The warning initially reported happens when using Java 9+. But the root problem is the inconsistent ObjectMapper initialization. Apparently, we neglected to resolve that. Without either the call to ObjectMapper.findAndRegisterModules, or explicitly adding the Java 8 Date/Time module, there would be problems with any payload that has a date/time property. Or are you saying that findAndRegisterModules is also no longer working? |
It seems so. When we tried using only |
I'm with this error in my teams bot, i've no ideia about what to do for fix. Even those samples don't work in my server. |
Is your feature request related to a problem? Please describe.
Problem: newer Jackson libraries (e.g. v 2.12.x) are unable to deserialize Java 8 time and date objects because a JDK8 Module is not added in ObjectMapper at com.microsoft.bot.schema.Serialization, that ObjectMapper is tightly coupled and as a client of the library we're unable to add additional modules in order to avoid this issue,
On jackson 2.12 the serialization throws a
Specific warnings thrown by jackson libs <2.12
Describe the solution you'd like
Register the modules into the object mapper with
The text was updated successfully, but these errors were encountered: