Okhttp java.net.ProtocolException: 流的意外结束
Okhttp java.net.ProtocolException: unexpected end of stream
我目前正致力于 Android 应用程序,我正在使用 okttp3 发出一个简单的 GET 请求。我使用我的烧瓶应用程序作为 API 端点。
代码Android:
OkHttpClient client = new OkHttpClient();
final Request request = new Request.Builder()
.url(url)
.build();
client.newCall(request).enqueue(new Callback() {
@Override
public void onResponse(@NotNull Call call, @NotNull Response response) throws IOException {
String s = response.body().string();
System.out.println(s);
}
@Override
public void onFailure(@NotNull Call call, @NotNull IOException e) {
System.out.println(e.getMessage());
}
});
代码瓶
@app.route('/abc', methods=["GET"])
def abc():
return jsonify({"test": "abc"})
当我使用 POSTMAN 发出请求时,我没有遇到任何问题:
postman get request
但是,当使用上面的 java 代码时,有时它会起作用,其他时候我会收到以下错误
D/OkHttp: java.net.ProtocolException: unexpected end of stream
at okhttp3.internal.http1.Http1ExchangeCodec$FixedLengthSource.read(Http1ExchangeCodec.kt:389)
at okhttp3.internal.connection.Exchange$ResponseBodySource.read(Exchange.kt:276)
at okio.Buffer.writeAll(Buffer.kt:1655)
at okio.RealBufferedSource.readString(RealBufferedSource.kt:95)
at okhttp3.ResponseBody.string(ResponseBody.kt:187)
at com.example.teste.MainActivity.onResponse(MainActivity.java:83)
at okhttp3.internal.connection.RealCall$AsyncCall.run(RealCall.kt:504)
at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1167)
D/OkHttp: at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:641)
at java.lang.Thread.run(Thread.java:764)
我已经尝试了多种解决方案,这些解决方案已在其他帖子中被推荐,例如:
OkHttpClient client = new OkHttpClient.Builder()
.retryOnConnectionFailure(true)
.build();
或
Request request = new Request.Builder()
.addHeader("Authorization", "Bearer " + apiToken)
.addHeader("content-type", "application/json")
.addHeader("Connection","close")
.url(uri)
.build();
但其中 none 有效。这里有什么问题?我尝试使用与其他虚拟 api 相同的代码发出请求,它总是有效。我的烧瓶 api 丢了什么?
错误发生在这里:
val read = super.read(sink, minOf(bytesRemaining, byteCount))
if (read == -1L) {
connection.noNewExchanges() // The server didn't supply the promised content length.
val e = ProtocolException("unexpected end of stream")
responseBodyComplete()
throw e
}
与服务器提供的内容长度有关。我该如何解决?
为每个请求添加一个拦截器并添加Connection-Close
header怎么样?如下。
okHttpClient = new OkHttpClient.Builder()
.addNetworkInterceptor(new Interceptor() {
@Override
public Response intercept(Chain chain) throws IOException {
Request request = chain.request().newBuilder().addHeader("Connection", "close").build();
return chain.proceed(request);
}
})
.build();
HTTP/1.1 defines the "close" connection option for the sender to signal that the connection will be closed after completion of the
response. For example,
Connection: close in either the request or the response header
fields indicates that the connection SHOULD NOT be considered
`persistent' (section 8.1) after the current request/response is
complete.
HTTP/1.1 applications that do not support persistent connections MUST
include the "close" connection option in every message.
只有在使用模拟器时才会出现异常。在设备上没有问题。
我目前正致力于 Android 应用程序,我正在使用 okttp3 发出一个简单的 GET 请求。我使用我的烧瓶应用程序作为 API 端点。 代码Android:
OkHttpClient client = new OkHttpClient();
final Request request = new Request.Builder()
.url(url)
.build();
client.newCall(request).enqueue(new Callback() {
@Override
public void onResponse(@NotNull Call call, @NotNull Response response) throws IOException {
String s = response.body().string();
System.out.println(s);
}
@Override
public void onFailure(@NotNull Call call, @NotNull IOException e) {
System.out.println(e.getMessage());
}
});
代码瓶
@app.route('/abc', methods=["GET"])
def abc():
return jsonify({"test": "abc"})
当我使用 POSTMAN 发出请求时,我没有遇到任何问题: postman get request 但是,当使用上面的 java 代码时,有时它会起作用,其他时候我会收到以下错误
D/OkHttp: java.net.ProtocolException: unexpected end of stream
at okhttp3.internal.http1.Http1ExchangeCodec$FixedLengthSource.read(Http1ExchangeCodec.kt:389)
at okhttp3.internal.connection.Exchange$ResponseBodySource.read(Exchange.kt:276)
at okio.Buffer.writeAll(Buffer.kt:1655)
at okio.RealBufferedSource.readString(RealBufferedSource.kt:95)
at okhttp3.ResponseBody.string(ResponseBody.kt:187)
at com.example.teste.MainActivity.onResponse(MainActivity.java:83)
at okhttp3.internal.connection.RealCall$AsyncCall.run(RealCall.kt:504)
at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1167)
D/OkHttp: at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:641)
at java.lang.Thread.run(Thread.java:764)
我已经尝试了多种解决方案,这些解决方案已在其他帖子中被推荐,例如:
OkHttpClient client = new OkHttpClient.Builder()
.retryOnConnectionFailure(true)
.build();
或
Request request = new Request.Builder()
.addHeader("Authorization", "Bearer " + apiToken)
.addHeader("content-type", "application/json")
.addHeader("Connection","close")
.url(uri)
.build();
但其中 none 有效。这里有什么问题?我尝试使用与其他虚拟 api 相同的代码发出请求,它总是有效。我的烧瓶 api 丢了什么?
错误发生在这里:
val read = super.read(sink, minOf(bytesRemaining, byteCount))
if (read == -1L) {
connection.noNewExchanges() // The server didn't supply the promised content length.
val e = ProtocolException("unexpected end of stream")
responseBodyComplete()
throw e
}
与服务器提供的内容长度有关。我该如何解决?
为每个请求添加一个拦截器并添加Connection-Close
header怎么样?如下。
okHttpClient = new OkHttpClient.Builder()
.addNetworkInterceptor(new Interceptor() {
@Override
public Response intercept(Chain chain) throws IOException {
Request request = chain.request().newBuilder().addHeader("Connection", "close").build();
return chain.proceed(request);
}
})
.build();
HTTP/1.1 defines the "close" connection option for the sender to signal that the connection will be closed after completion of the response. For example,
Connection: close in either the request or the response header fields indicates that the connection SHOULD NOT be considered `persistent' (section 8.1) after the current request/response is complete.
HTTP/1.1 applications that do not support persistent connections MUST include the "close" connection option in every message.
只有在使用模拟器时才会出现异常。在设备上没有问题。