3

我正在与 REST API 集成,所以我正在使用 Retrofit。我需要点击的网址是:

http://{{server}}/api/v1/stuff/{{id}}/deactivate

我创建了一个实现 API 的接口:

@PUT("/api/v1/stuff/{id}/deactivate")
String deactivate(@Path("id") String id);

问题是当我调用它失败的方法时,出现以下堆栈跟踪:

E/AndroidRuntime( 3046): Caused by: retrofit.converter.ConversionException: com.google.gson.JsonSyntaxException: com.google.gson.stream.MalformedJsonException: Use JsonReader.setLenient(true) to accept malformed JSON at line 1 column 15  
E/AndroidRuntime( 3046):        at retrofit.converter.GsonConverter.fromBody(GsonConverter.java:67)    
E/AndroidRuntime( 3046):        at retrofit.RestAdapter$RestHandler.invokeRequest(RestAdapter.java:393) 
E/AndroidRuntime( 3046):        ... 11 more 
E/AndroidRuntime( 3046): Caused by: com.google.gson.JsonSyntaxException: com.google.gson.stream.MalformedJsonException: Use JsonReader.setLenient(true) to accept malformed JSON at line 1 column 15   
E/AndroidRuntime( 3046):        at com.google.gson.Gson.assertFullConsumption(Gson.java:779) 
E/AndroidRuntime( 3046):        at com.google.gson.Gson.fromJson(Gson.java:769)   
E/AndroidRuntime( 3046):  at retrofit.converter.GsonConverter.fromBody(GsonConverter.java:63) 
E/AndroidRuntime( 3046):        ... 12 more 
E/AndroidRuntime( 3046): Caused by: com.google.gson.stream.MalformedJsonException: Use JsonReader.setLenient(true) to accept malformed JSON at line 1 column 15 
E/AndroidRuntime( 3046):        at com.google.gson.stream.JsonReader.syntaxError(JsonReader.java:1505) 
E/AndroidRuntime( 3046):        at com.google.gson.stream.JsonReader.checkLenient(JsonReader.java:1386) 
E/AndroidRuntime( 3046):        at com.google.gson.stream.JsonReader.doPeek(JsonReader.java:531) 
E/AndroidRuntime( 3046):        at com.google.gson.stream.JsonReader.peek(JsonReader.java:414) 
E/AndroidRuntime( 3046):        at com.google.gson.Gson.assertFullConsumption(Gson.java:775) 
E/AndroidRuntime( 3046):        ... 14 more

我相信这是由于我没有在体内张贴任何东西造成的。解决此问题的最佳方法是什么?

注意:我已经成功使用 POSTMan 调用 API。

4

2 回答 2

3

使用以下命令打开完整调试:

setLogLevel(RestAdapter.LogLevel.FULL)

并发现 Gson 解析错误是因为从服务器返回的 JSON 格式不正确。我与服务器人员进行了“交谈”以修复它。

对不起,空空如也的红鲱鱼放了思想。我想我忘记了相关性并不表示因果关系。

于 2014-02-10T16:32:51.207 回答
0

我在改造时遇到了这个问题。我最初有以下内容:

@POST("/item/{id}")
void postItem(@Path("id") int id, Callback<String> callback);

这给了我一个 okhttp 的例外。我将其更改为以下内容:

@POST("/item/{id}")
void postItem(@Path("id") int id, @Body String body, Callback<String> callback);

然后像这样处理它:

service.postItem(id, "", callback);
于 2015-06-03T21:21:22.733 回答