在我的应用中,我使用Retrofit库发出同步 PUT
请求。问题是:有时库会抛出EOFException
个。
以下是其中一种情况的堆栈跟踪
29099-29269/com.mycompany.myapp D/Retrofit﹕ java.io.EOFException
at okio.RealBufferedSource.readUtf8LineStrict(RealBufferedSource.java:192)
at com.squareup.okhttp.internal.http.HttpConnection.readResponse(HttpConnection.java:189)
at com.squareup.okhttp.internal.http.HttpTransport.readResponseHeaders(HttpTransport.java:101)
at com.squareup.okhttp.internal.http.HttpEngine.readResponse(HttpEngine.java:676)
at com.squareup.okhttp.internal.huc.HttpURLConnectionImpl.execute(HttpURLConnectionImpl.java:426)
at com.squareup.okhttp.internal.huc.HttpURLConnectionImpl.getResponse(HttpURLConnectionImpl.java:371)
at com.squareup.okhttp.internal.huc.HttpURLConnectionImpl.getResponseCode(HttpURLConnectionImpl.java:466)
at retrofit.client.UrlConnectionClient.readResponse(UrlConnectionClient.java:73)
at retrofit.client.UrlConnectionClient.execute(UrlConnectionClient.java:38)
at retrofit.RestAdapter$RestHandler.invokeRequest(RestAdapter.java:321)
at retrofit.RestAdapter$RestHandler.invoke(RestAdapter.java:240)
at $Proxy7.addEvents(Native Method)
at com.mycompany.myapp.api.MyService.addEvents(MyService.java:59)
我尝试了以下展示的解决方案,但在我的案例中没有一个有用:
以下是我在应用中创建RestAdapter
的方式:
OkHttpClient okHttpClient = new OkHttpClient();
RestAdapter restAdapter = new RestAdapter.Builder()
.setEndpoint(Url)
.setRequestInterceptor(new RequestInterceptor()
{
@Override
public void intercept(RequestFacade request)
{
request.addHeader("Accept", "application/json");
request.addHeader("Content-Type", "application/json");
}
})
.setClient(new OkClient(okHttpClient))
.setLogLevel(RestAdapter.LogLevel.FULL)
.setErrorHandler(new MyErrorHandler())
.build();
是否有人知道该问题的其他解决方案?
顺便说一句,我不能使用涉及System.setProperty("http.keepAlive", "false");
的解决方案,因为出于性能原因,我需要保持连接处于活动状态。
答案 0 :(得分:1)
此问题通常可能是由网络错误引起的。如果它一致地再现,请考虑内容长度和请求超时的潜在原因。有时超时的网络请求可能会返回不正确的文件结束。结果会抛出这个错误。
答案 1 :(得分:0)
也许EOF会丢失网络连接或超时。尝试增加超时并确保设置keep-alive。
答案 2 :(得分:0)