JsonMappingException: не найден подходящий конструктор для типа

Учитывая конечную точку API

@ApiMethod(name = "sendChallenge", httpMethod = HttpMethod.POST)
public ExchangeList sendChallenge(ChallengeData request) throws Exception {
  return getFromDBThenProcess(request);
}

И передний конец (Android) вызов конечной точки

ExchangeList transfers = service.sendChallenge(request).execute();

Я получаю следующую трассировку стека от LogCat.

Примечание. Я наблюдаю за своей консолью сервера (localhost), и мне не звонили.

Трассировки стека:

04-08 14:58:53.261: D/dalvikvm(940): GC_CONCURRENT freed 1394K, 15% free 12495K/14599K, paused 15ms+15ms, total 75ms
… //[many of those `freed` lines]
04-08 14:58:54.742: D/dalvikvm(940): GC_CONCURRENT freed 1394K, 15% free 12506K/14599K, paused 15ms+16ms, total 85ms
04-08 14:58:55.562: W/System.err(940): com.google.api.client.googleapis.json.GoogleJsonResponseException: 400 Bad Request
04-08 14:58:55.562: W/System.err(940): {
04-08 14:58:55.562: W/System.err(940):   "code": 0,
04-08 14:58:55.562: W/System.err(940):   "message": "com.google.appengine.repackaged.org.codehaus.jackson.map.JsonMappingException: No suitable constructor found for type [simple type, class com.myapi.games.message.ChallengeData]: can not instantiate from JSON object (need to add/enable type information?)\n at [Source: N/A; line: -1, column: -1]"
04-08 14:58:55.572: W/System.err(940): }
04-08 14:58:55.572: W/System.err(940):  at com.google.api.client.googleapis.services.json.AbstractGoogleJsonClientRequest.newExceptionOnError(AbstractGoogleJsonClientRequest.java:111)
04-08 14:58:55.572: W/System.err(940):  at com.google.api.client.googleapis.services.json.AbstractGoogleJsonClientRequest.newExceptionOnError(AbstractGoogleJsonClientRequest.java:38)
04-08 14:58:55.572: W/System.err(940):  at com.google.api.client.googleapis.services.AbstractGoogleClientRequest$1.interceptResponse(AbstractGoogleClientRequest.java:314)
04-08 14:58:55.572: W/System.err(940):  at com.google.api.client.http.HttpRequest.execute(HttpRequest.java:1060)
04-08 14:58:55.572: W/System.err(940):  at com.google.api.client.googleapis.services.AbstractGoogleClientRequest.executeUnparsed(AbstractGoogleClientRequest.java:412)
04-08 14:58:55.572: W/System.err(940):  at com.google.api.client.googleapis.services.AbstractGoogleClientRequest.executeUnparsed(AbstractGoogleClientRequest.java:345)
04-08 14:58:55.572: W/System.err(940):  at com.google.api.client.googleapis.services.AbstractGoogleClientRequest.execute(AbstractGoogleClientRequest.java:463)
04-08 14:58:55.572: W/System.err(940):  at com.myapi.games.utils.sendChallenge.doInBackground(sendChallenge.java:70)
04-08 14:58:55.582: W/System.err(940):  at com.myapi.games.utils.sendChallenge.doInBackground(sendChallenge.java:1)
04-08 14:58:55.582: W/System.err(940):  at android.os.AsyncTask$2.call(AsyncTask.java:287)
04-08 14:58:55.582: W/System.err(940):  at java.util.concurrent.FutureTask$Sync.innerRun(FutureTask.java:305)
04-08 14:58:55.582: W/System.err(940):  at java.util.concurrent.FutureTask.run(FutureTask.java:137)
04-08 14:58:55.582: W/System.err(940):  at android.os.AsyncTask$SerialExecutor$1.run(AsyncTask.java:230)
04-08 14:58:55.592: W/System.err(940):  at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1076)
04-08 14:58:55.592: W/System.err(940):  at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:569)
04-08 14:58:55.592: W/System.err(940):  at java.lang.Thread.run(Thread.java:856)

Речь идет о Android-проекте, связанном с приложением. Все компилируется без ошибок и т. Д. Также POJO ChallengeData состоит из трех других POJO, похожих на:

public class ChallengeData{

  Credit credit;
  Coin  coin;
  Friend friend;

  //getters and setters
}

Тогда и Credit, и Coin содержат только простые поля (например, int и String), но Friend содержит несколько простых полей и еще одно POJO.

Я действительно не думаю, что глубина JSON (то есть отношения POJO) должна иметь значение. Но я все же включаю детали.

1 ответ

Решение

Возможно, вы получаете эту ошибку, потому что вы отправляете изображения через конечную точку API, и вы забыли закодировать их в Base64, Вы должны закодировать все изображения в строку base64. Вот ссылка с фрагментом кода, показывающим, как это сделать. Помните, что вы кодируете от байта к String, Причина, по-моему, заключается в том, что вы упоминаете, что ваш сервер не получает никакого удара, и все же вы получаете 400 Bad Request ошибка, которая означает, что Google перехватывает ваш звонок и не может проанализировать запрос. Так что попробуйте.

Другие вопросы по тегам