Hi,
Yes, sorry I meant unmarshaling throughout.
In Jersey 1.5 and Jackson 1.9, I was able to use the @XmlJavaAdapter annotation to control the unmarshaling. The side effect was that the JSON generated for a Double would contain quotes, which is invalid JSON. I used another annotation @JsonSerialize to fix that.
With the combination of Jersey 2.17 and Jackson 2.3.2, the custom JsonSerialize provided seems to be ignored in favor of the custom XmlJavaAdapter marshal method. I have a Jackson thread here on that:
Unless something happens there, I'm resigned to just returning a custom message via an Exception mapper that maps the Moxy ConversionException. So a comprehensive validation of all errors ( unmarshaling as well as business validation ) in the POST or PUT cannot be done when there is a single unmarshaling error encountered.
-------- Original message --------
From: "japod [via Jersey]" <ml-node+s576304n7583224h3_at_n2.nabble.com>
Date:03/26/2015 11:56 AM (GMT-06:00)
To: naresh <baliga_naresh_at_yahoo.com>
Cc:
Subject: Re: Catch marshaling errors and present in one go
Hi Naresh,
please see inline…
On 26 Mar 2015, at 11:25, naresh <[hidden email]> wrote:
Hi,
I don't think bean validation will work, as it might never get to it due to the marshaling error encountered earlier on.
For marshaling case, validation will happen before you send data over the wire. So no problem here. But you are probably talking about
unmarshalling, and then you are right.
Basically need to get a callback on the marshaling exception, do something, but more importantly Jersey needs to keep going on and not stop on the first exception.
Jersey does not do marshaling itself. It delegates to Jackson MBW. There is a possibility to configure Jackson within Jersey
so that it does not stick with the default behaviour:
https://jersey.java.net/documentation/latest/media.html#json.jackson
The MessageBodyWorkers may work.
What is the "normal" behavior in a REST POST or PUT though, where a user sends Strings that cannot marshal into the member variable data type in the POJO? Bail on the first bad marshal encountered? If that's normal, I guess that's what I might consider doing.
Ah, you mean unmarshaling. Anyway, if deserialization goes wrong you will get a 400/500 response back by default (depends on how bad the data are O:-)
~Jakub
Sent from my T-Mobile 4G LTE Device
-------- Original message --------
From: "japod [via Jersey]" <<a href="x-msg://9/user/SendEmail.jtp?type=node&node=7583223&i=0" target="_top" rel="nofollow" link="external" style="font-family: Helvetica; font-size: 12px; font-style: normal; font-variant: normal; font-weight: normal; letter-spacing: normal; line-height: normal; orphans: auto; text-align: start; text-indent: 0px; text-transform: none; white-space: normal; widows: auto; word-spacing: 0px; -webkit-text-stroke-width: 0px;" class="">[hidden email]>
Date:03/26/2015 4:30 AM (GMT-06:00)
To: naresh <<a href="x-msg://9/user/SendEmail.jtp?type=node&node=7583223&i=1" target="_top" rel="nofollow" link="external" style="font-family: Helvetica; font-size: 12px; font-style: normal; font-variant: normal; font-weight: normal; letter-spacing: normal; line-height: normal; orphans: auto; text-align: start; text-indent: 0px; text-transform: none; white-space: normal; widows: auto; word-spacing: 0px; -webkit-text-stroke-width: 0px;" class="">[hidden email]>
Cc:
Subject: Re: Catch marshaling errors and present in one go
Hi Naresh,
I am not sure i completely understand you use case.
However to better controll what happens when marshalling goes wrong
you should be always able to register your custom message body provider,
that would just delegate to the “original” one and process any exceptions being thrown.
Please see the following doc for some details:
https://jersey.java.net/documentation/latest/user-guide.html#d0e7605
In the above doc, marshalling is done within a resource method, but the same
pattern (MessageBodyWorkers usage) could be applied also within a custom
message body reader/writer.
Otherwise, the following doc discusses bean validation feature,
that you might want to consider to apply to your use case instead:
https://jersey.java.net/documentation/latest/user-guide.html#bean-validation
HTH,
~Jakub
On 26 Mar 2015, at 09:30, naresh <<a href="x-msg://9/user/SendEmail.jtp?type=node&node=7583222&i=0" target="_top" rel="nofollow" link="external" class="">[hidden email]> wrote:
Hi,
I'm using Jersey 2.17 and am using Jackson with JAXB annotations on my
representations.
These annotations are used for producing and consuming JSON as well as XML.
If a user POSTs a String to a data member (buried deep inside my
representation object) that is a Double, I wish to catch the resulting
marshal error and return a nicely formatted message.
I want to catch *all* such marshaling errors before presenting my error
response back, so that there is complete feedback to the user on what they
need to correct in their POST.
All I can do currently is map the resulting exception and present an error
for the first such encountered marshaling error.
--
View this message in context: http://jersey.576304.n2.nabble.com/Catch-marshaling-errors-and-present-in-one-go-tp7583221.html
Sent from the Jersey mailing list archive at Nabble.com.
If you reply to this email, your message will be added to the discussion below:
http://jersey.576304.n2.nabble.com/Catch-marshaling-errors-and-present-in-one-go-tp7583221p7583222.html
To unsubscribe from Catch marshaling errors and present in one go, click here.
NAML
View this message in context: Re: Catch marshaling errors and present in one go
Sent from the Jersey mailing list archive at Nabble.com.
If you reply to this email, your message will be added to the discussion below:
http://jersey.576304.n2.nabble.com/Catch-marshaling-errors-and-present-in-one-go-tp7583221p7583224.html
To unsubscribe from Catch marshaling errors and present in one go, click here.
NAML
--
View this message in context: http://jersey.576304.n2.nabble.com/Catch-marshaling-errors-and-present-in-one-go-tp7583221p7583225.html
Sent from the Jersey mailing list archive at Nabble.com.