杰克逊:无法从START_ARRAY令牌中反序列化实例

时间:2014-03-12 08:38:33

标签: java json web-services

我需要向web服务发送一个帖子请求,但它会返回以下异常

 java.io.IOException: Server returned HTTP response code: 500 for URL domain.com

实际的服务器响应如下:

<html>
<head><title>500 Servlet Exception</title></head>
<body>
<h1>500 Servlet Exception</h1>
<code><pre>
<script language='javascript' type='text/javascript'>
function show() { document.getElementById('trace').style.display = ''; }
</script>
<a style="text-decoration" href="javascript:show();">[show]</a> org.codehaus.jackson.map.JsonMappingException: Can not deserialize instance
of com.domain.service.beans.spec.SearchSpec out of START_ARRAY token
 at [Source: com.caucho.server.connection.ServletInputStreamImpl@7aafd4d3; line: 1, column: 1]
<span id="trace" style="display:none">
org.codehaus.jackson.map.JsonMappingException: Can not deserialize instance
of com.domain.service.beans.spec.SearchSpec out of START_ARRAY token
 at [Source: com.caucho.server.connection.ServletInputStreamImpl@7aafd4d3; line: 1, column: 1]
    at org.codehaus.jackson.map.JsonMappingException.from(JsonMappingException.java:163)
    at org.codehaus.jackson.map.deser.StdDeserializationContext.mappingException(StdDeserializationContext.java:219)
    at org.codehaus.jackson.map.deser.StdDeserializationContext.mappingException(StdDeserializationContext.java:212)
    at org.codehaus.jackson.map.deser.BeanDeserializer.deserializeFromArray(BeanDeserializer.java:875)
    at org.codehaus.jackson.map.deser.BeanDeserializer.deserialize(BeanDeserializer.java:597)
    at org.codehaus.jackson.map.ObjectMapper._readMapAndClose(ObjectMapper.java:2732)
    at org.codehaus.jackson.map.ObjectMapper.readValue(ObjectMapper.java:1923)
    at org.springframework.http.converter.json.MappingJacksonHttpMessageConverter.readInternal(MappingJacksonHttpMessageConverter.java:135)
    at org.springframework.http.converter.AbstractHttpMessageConverter.read(AbstractHttpMessageConverter.java:154)
    at org.springframework.web.bind.annotation.support.HandlerMethodInvoker.readWithMessageConverters(HandlerMethodInvoker.java:643)
    at org.springframework.web.bind.annotation.support.HandlerMethodInvoker.resolveRequestBody(HandlerMethodInvoker.java:607)
    at org.springframework.web.bind.annotation.support.HandlerMethodInvoker.resolveHandlerArguments(HandlerMethodInvoker.java:346)
    at org.springframework.web.bind.annotation.support.HandlerMethodInvoker.invokeHandlerMethod(HandlerMethodInvoker.java:171)
    at org.springframework.web.servlet.mvc.annotation.AnnotationMethodHandlerAdapter.invokeHandlerMethod(AnnotationMethodHandlerAdapter.java:427)
    at org.springframework.web.servlet.mvc.annotation.AnnotationMethodHandlerAdapter.handle(AnnotationMethodHandlerAdapter.java:415)
    at org.springframework.web.servlet.DispatcherServlet.doDispatch(DispatcherServlet.java:788)
    at org.springframework.web.servlet.DispatcherServlet.doService(DispatcherServlet.java:717)
    at org.springframework.web.servlet.FrameworkServlet.processRequest(FrameworkServlet.java:644)
    at org.springframework.web.servlet.FrameworkServlet.doPost(FrameworkServlet.java:560)
    at javax.servlet.http.HttpServlet.service(HttpServlet.java:153)
    at javax.servlet.http.HttpServlet.service(HttpServlet.java:91)
    at com.caucho.server.dispatch.ServletFilterChain.doFilter(ServletFilterChain.java:103)
    at com.domain.service.filter.LoggingFilter.doFilter(LoggingFilter.java:91)
    at com.caucho.server.dispatch.FilterFilterChain.doFilter(FilterFilterChain.java:87)
    at com.caucho.server.webapp.WebAppFilterChain.doFilter(WebAppFilterChain.java:187)
    at com.caucho.server.dispatch.ServletInvocation.service(ServletInvocation.java:265)
    at com.caucho.server.hmux.HmuxRequest.handleRequest(HmuxRequest.java:436)
    at com.caucho.server.port.TcpConnection.run(TcpConnection.java:682)
    at com.caucho.util.ThreadPool$Item.runTasks(ThreadPool.java:743)
    at com.caucho.util.ThreadPool$Item.run(ThreadPool.java:662)
    at java.lang.Thread.run(Thread.java:662)
</span>
</pre></code>
</body></html>

我发送的请求基于以下

Method: POST
This returns a list of products
Dates are optional.
Destination ID and currencyCode are required.
JSON Request Parameters
{

"startDate":"2013-10-25", "endDate":"2013-10-27", "topX":"1-5", "destId":684, "currencyCode":"EUR", "catId":0,
"subCatId":0, "dealsOnly":false, "sortOrder":"PRICE_FROM_A"
}

so r t O r d e r
Valid sort orders:
TOP_SELLERS - The top sellers - default sortOrder 
REVIEW_AVG_RATING_A - Traveler Rating (low->high) Average 
REVIEW_AVG_RATING_D - Traveler Rating (high->low) Average 
PRICE_FROM_A - Price (low->high)
PRICE_FROM_D - Price (high->low)

topX
For returning results in particular positions. e.g. a value of 11-15 will return the results in position 11 to 15 based on the sort (total of 5 products). Useful for pagination.

catId
Category id from the /service/taxonomy/categories

subCatId
Sub Category id from the /service/taxonomy/categories

dealsOnly
Applicable only when there is no startDate/endDate as it is a destionation search only feature. This API is used for obtaining lists of products for destination pages.

我的代码

 public void Search() {


        JSONObject obj = new JSONObject();
        obj.put("startDate", "2014-08-25");
        obj.put("endDate", "2014-08-25");
        obj.put("topX", "1-5");
        obj.put("destId", 684);
        obj.put("currencyCode", "EUR");
        obj.put("catId", 21);
        obj.put("subCatId", 78);
        obj.put("dealsOnly", false);
        obj.put("sortOrder","PRICE_FROM_A");

        JSONArray jsarray = new JSONArray();
        jsarray.add(obj);
        putDataToServer(jsarray.toJSONString());

    }

    public void putDataToServer(String returnedJObject) {

try{
        java.lang.String contentToPost = returnedJObject;

        java.net.URLConnection connection = new java.net.URL("domain.com").openConnection();

        connection.setUseCaches(true);
        connection.setDoInput(true);
        connection.setDoOutput(true);
        connection.setRequestProperty("Content-Length", "" + contentToPost.length());

        connection.setRequestProperty("Content-Type", "application/json");
        connection.setRequestProperty("Cache-Control", "no-cache");

        java.io.OutputStream stream = connection.getOutputStream();
        stream.write(contentToPost.getBytes());
        stream.close();
        System.err.println("request is sent");

        BufferedReader br = new BufferedReader(new InputStreamReader(connection.getInputStream()));
        System.err.println(br.readLine());
        br.close();

    }catch(Exception e){
            e.printStackTrace();
            }
    }

1 个答案:

答案 0 :(得分:0)

服务器错误表明它不期望​​一个对象数组。删除此代码

JSONArray jsarray = new JSONArray();
jsarray.add(obj);