2016-04-26 160 views
4

有時JAR-RS客戶端發送錯誤的語法請求主體。服務器應迴應HTTP status 400 (Bad Request),但它迴應HTTP status 500 (Internal Server Error)HTTP狀態500而不是HTTP狀態的JAX-RS響應400

代碼:

JAX-B模型類:

@XmlRootElement(namespace = "http://www.test.com/test") 
@XmlAccessorType(value = XmlAccessType.FIELD) 
public class TestModel { 

    @XmlElement 
    private String id; 
} 

JAX-RS資源類:

@Path("test") 
public class TestResource { 

    @POST 
    @Consumes(MediaType.APPLICATION_JSON) 
    public void create(TestModel testModel) { 
     // some code 
    } 
} 

CXF配置:

<jaxrs:server address="/rest" id="test" staticSubresourceResolution="true"> 
    <jaxrs:serviceBeans> 
     <ref bean="testResource" /> 
    </jaxrs:serviceBeans> 
    <jaxrs:providers> 
     <bean class="com.fasterxml.jackson.jaxrs.json.JacksonJaxbJsonProvider" /> 
    </jaxrs:providers> 
</jaxrs:server> 

例子:

請求正文:

{"id2": "test"} 

id2是錯誤的,所以客戶應該得到一個HTTP status 400,但它得到HTTP status 500

服務器日誌:

Caused by: com.fasterxml.jackson.databind.exc.UnrecognizedPropertyException: Unrecognized field "id2" (class test.TestModel), not marked as ignorable (one known property: "id"]) 
    at [Source: [email protected]; line: 1, column: 10] (through reference chain: test.TestModel["id2"]) 
    at com.fasterxml.jackson.databind.exc.UnrecognizedPropertyException.from(UnrecognizedPropertyException.java:51) 
    at com.fasterxml.jackson.databind.DeserializationContext.reportUnknownProperty(DeserializationContext.java:839) 
    at com.fasterxml.jackson.databind.deser.std.StdDeserializer.handleUnknownProperty(StdDeserializer.java:1045) 
    at com.fasterxml.jackson.databind.deser.BeanDeserializerBase.handleUnknownProperty(BeanDeserializerBase.java:1352) 
    at com.fasterxml.jackson.databind.deser.BeanDeserializerBase.handleUnknownVanilla(BeanDeserializerBase.java:1330) 
    at com.fasterxml.jackson.databind.deser.BeanDeserializer.vanillaDeserialize(BeanDeserializer.java:264) 
    at com.fasterxml.jackson.databind.deser.BeanDeserializer.deserialize(BeanDeserializer.java:125) 
    at com.fasterxml.jackson.databind.ObjectReader._bind(ObjectReader.java:1470) 
    at com.fasterxml.jackson.databind.ObjectReader.readValue(ObjectReader.java:912) 
    at com.fasterxml.jackson.jaxrs.base.ProviderBase.readFrom(ProviderBase.java:811) 
    at org.apache.cxf.jaxrs.utils.JAXRSUtils.readFromMessageBodyReader(JAXRSUtils.java:1343) 
    at org.apache.cxf.jaxrs.utils.JAXRSUtils.readFromMessageBody(JAXRSUtils.java:1294) 
    at org.apache.cxf.jaxrs.utils.JAXRSUtils.processParameter(JAXRSUtils.java:826) 
    at org.apache.cxf.jaxrs.utils.JAXRSUtils.processParameters(JAXRSUtils.java:789) 
    at org.apache.cxf.jaxrs.interceptor.JAXRSInInterceptor.processRequest(JAXRSInInterceptor.java:212) 
    ... 68 more 

是否有配置傑克遜和/或CXF返回HTTP狀態400錯誤的語法要求身體無schema validationbean validation的方法嗎?

回答

2

問題是未映射到響應的異常(通過ExceptionMapper s)轉換爲一般服務器錯誤響應,因爲運行時不知道如何處理異常。

jackson-jaxrs-provider模塊有ExceptionMapper s來處理Jackson基本異常類JsonMappingExceptionJsonParseException。映射器分別爲JsonMappingExceptionMapperJsonParseExceptionMapper。這些映射器將異常映射到400響應以及作爲響應主體的異常消息。如果你不喜歡這個響應體,你可以編寫自己的映射器。