HTTPCLIENT-1981: disallow TRACE requests with an enclosed entity
This commit is contained in:
parent
8fdc2ec1b8
commit
7fbbe7c98f
|
@ -430,6 +430,11 @@ public class AsyncRequestBuilder {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (entityProducerCopy != null && StandardMethods.TRACE.name().equalsIgnoreCase(method)) {
|
||||||
|
throw new IllegalStateException(StandardMethods.TRACE.name() + " requests may not include an entity.");
|
||||||
|
}
|
||||||
|
|
||||||
final ConfigurableHttpRequest request = host != null ?
|
final ConfigurableHttpRequest request = host != null ?
|
||||||
new ConfigurableHttpRequest(method, host, !TextUtils.isBlank(path) ? path : "/") :
|
new ConfigurableHttpRequest(method, host, !TextUtils.isBlank(path) ? path : "/") :
|
||||||
new ConfigurableHttpRequest(method, uri != null ? uri : URI.create("/"));
|
new ConfigurableHttpRequest(method, uri != null ? uri : URI.create("/"));
|
||||||
|
|
|
@ -29,6 +29,8 @@ package org.apache.hc.client5.http.classic.methods;
|
||||||
|
|
||||||
import java.net.URI;
|
import java.net.URI;
|
||||||
|
|
||||||
|
import org.apache.hc.core5.http.HttpEntity;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* HTTP TRACE method.
|
* HTTP TRACE method.
|
||||||
*
|
*
|
||||||
|
@ -60,4 +62,9 @@ public class HttpTrace extends HttpUriRequestBase {
|
||||||
this(URI.create(uri));
|
this(URI.create(uri));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void setEntity(final HttpEntity entity) {
|
||||||
|
throw new IllegalStateException(METHOD_NAME + " requests may not include an entity.");
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -482,6 +482,11 @@ public class RequestBuilder {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (entityCopy != null && StandardMethods.TRACE.name().equalsIgnoreCase(method)) {
|
||||||
|
throw new IllegalStateException(StandardMethods.TRACE.name() + " requests may not include an entity.");
|
||||||
|
}
|
||||||
|
|
||||||
final HttpUriRequestBase result = new HttpUriRequestBase(method, uriNotNull);
|
final HttpUriRequestBase result = new HttpUriRequestBase(method, uriNotNull);
|
||||||
result.setVersion(this.version != null ? this.version : HttpVersion.HTTP_1_1);
|
result.setVersion(this.version != null ? this.version : HttpVersion.HTTP_1_1);
|
||||||
if (this.headerGroup != null) {
|
if (this.headerGroup != null) {
|
||||||
|
|
|
@ -0,0 +1,42 @@
|
||||||
|
/*
|
||||||
|
* ====================================================================
|
||||||
|
* Licensed to the Apache Software Foundation (ASF) under one
|
||||||
|
* or more contributor license agreements. See the NOTICE file
|
||||||
|
* distributed with this work for additional information
|
||||||
|
* regarding copyright ownership. The ASF licenses this file
|
||||||
|
* to you under the Apache License, Version 2.0 (the
|
||||||
|
* "License"); you may not use this file except in compliance
|
||||||
|
* with the License. You may obtain a copy of the License at
|
||||||
|
*
|
||||||
|
* http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
*
|
||||||
|
* Unless required by applicable law or agreed to in writing,
|
||||||
|
* software distributed under the License is distributed on an
|
||||||
|
* "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
|
||||||
|
* KIND, either express or implied. See the License for the
|
||||||
|
* specific language governing permissions and limitations
|
||||||
|
* under the License.
|
||||||
|
* ====================================================================
|
||||||
|
*
|
||||||
|
* This software consists of voluntary contributions made by many
|
||||||
|
* individuals on behalf of the Apache Software Foundation. For more
|
||||||
|
* information on the Apache Software Foundation, please see
|
||||||
|
* <http://www.apache.org/>.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
package org.apache.hc.client5.http.async.methods;
|
||||||
|
|
||||||
|
import org.apache.hc.core5.http.nio.entity.BasicAsyncEntityProducer;
|
||||||
|
import org.junit.Test;
|
||||||
|
|
||||||
|
public class TestAsyncRequestBuilder {
|
||||||
|
|
||||||
|
@Test(expected = IllegalStateException.class)
|
||||||
|
public void testBuildTraceWithEntity() {
|
||||||
|
final AsyncRequestBuilder builder = AsyncRequestBuilder.create("TRACE").setUri("/path");
|
||||||
|
builder.setEntity(new BasicAsyncEntityProducer("stuff"));
|
||||||
|
builder.build();
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
|
@ -0,0 +1,40 @@
|
||||||
|
/*
|
||||||
|
* ====================================================================
|
||||||
|
* Licensed to the Apache Software Foundation (ASF) under one
|
||||||
|
* or more contributor license agreements. See the NOTICE file
|
||||||
|
* distributed with this work for additional information
|
||||||
|
* regarding copyright ownership. The ASF licenses this file
|
||||||
|
* to you under the Apache License, Version 2.0 (the
|
||||||
|
* "License"); you may not use this file except in compliance
|
||||||
|
* with the License. You may obtain a copy of the License at
|
||||||
|
*
|
||||||
|
* http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
*
|
||||||
|
* Unless required by applicable law or agreed to in writing,
|
||||||
|
* software distributed under the License is distributed on an
|
||||||
|
* "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
|
||||||
|
* KIND, either express or implied. See the License for the
|
||||||
|
* specific language governing permissions and limitations
|
||||||
|
* under the License.
|
||||||
|
* ====================================================================
|
||||||
|
*
|
||||||
|
* This software consists of voluntary contributions made by many
|
||||||
|
* individuals on behalf of the Apache Software Foundation. For more
|
||||||
|
* information on the Apache Software Foundation, please see
|
||||||
|
* <http://www.apache.org/>.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
package org.apache.hc.client5.http.classic.methods;
|
||||||
|
|
||||||
|
import org.junit.Test;
|
||||||
|
|
||||||
|
public class TestHttpTrace {
|
||||||
|
|
||||||
|
@Test(expected = IllegalStateException.class)
|
||||||
|
public void testHttpTraceSetEntity() {
|
||||||
|
final HttpTrace httpTrace = new HttpTrace("/path");
|
||||||
|
httpTrace.setEntity(null);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
|
@ -264,6 +264,13 @@ public class TestRequestBuilder {
|
||||||
assertBuild(StandardCharsets.ISO_8859_1);
|
assertBuild(StandardCharsets.ISO_8859_1);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Test(expected = IllegalStateException.class)
|
||||||
|
public void testBuildTraceWithEntity() {
|
||||||
|
final RequestBuilder requestBuilder = RequestBuilder.create("TRACE").setUri("/path");
|
||||||
|
requestBuilder.setEntity(new StringEntity("foo"));
|
||||||
|
requestBuilder.build();
|
||||||
|
}
|
||||||
|
|
||||||
private void assertBuild(final Charset charset) throws Exception {
|
private void assertBuild(final Charset charset) throws Exception {
|
||||||
final RequestBuilder requestBuilder = RequestBuilder.create("GET").setCharset(charset);
|
final RequestBuilder requestBuilder = RequestBuilder.create("GET").setCharset(charset);
|
||||||
requestBuilder.setUri("https://somehost.com/stuff");
|
requestBuilder.setUri("https://somehost.com/stuff");
|
||||||
|
|
Loading…
Reference in New Issue