Fixes #1878 - Handle 100 Continue response without Expect header.

Fixed - again - accept().
This commit is contained in:
Simone Bordet 2017-10-09 15:59:41 +02:00
parent 6fd3351272
commit a436b9eb6c
1 changed files with 7 additions and 6 deletions

View File

@ -24,6 +24,8 @@ import org.eclipse.jetty.client.api.Request;
import org.eclipse.jetty.client.api.Response;
import org.eclipse.jetty.client.api.Result;
import org.eclipse.jetty.client.util.BufferingResponseListener;
import org.eclipse.jetty.http.HttpHeader;
import org.eclipse.jetty.http.HttpHeaderValue;
import org.eclipse.jetty.http.HttpStatus;
/**
@ -50,12 +52,11 @@ public class ContinueProtocolHandler implements ProtocolHandler
@Override
public boolean accept(Request request, Response response)
{
if (response.getStatus() == HttpStatus.CONTINUE_100)
{
HttpConversation conversation = ((HttpRequest)request).getConversation();
return conversation.getAttribute(ATTRIBUTE) == null;
}
return false;
boolean is100 = response.getStatus() == HttpStatus.CONTINUE_100;
boolean expect100 = request.getHeaders().contains(HttpHeader.EXPECT, HttpHeaderValue.CONTINUE.asString());
HttpConversation conversation = ((HttpRequest)request).getConversation();
boolean handled100 = conversation.getAttribute(ATTRIBUTE) != null;
return (is100 || expect100) && !handled100;
}
@Override