254 lines
11 KiB
Diff
254 lines
11 KiB
Diff
From cf77cc545de0488fb89e24294151504a7432df74 Mon Sep 17 00:00:00 2001
|
|
From: Mark Thomas <markt@apache.org>
|
|
Date: Tue, 13 Dec 2022 17:55:34 +0000
|
|
Subject: [PATCH] Update packaged renamed fork of Commons File Upload
|
|
|
|
Origin: https://github.com/apache/tomcat/commit/cf77cc545de0488fb89e24294151504a7432df74
|
|
|
|
---
|
|
.../apache/catalina/connector/Request.java | 12 ++++-
|
|
.../apache/tomcat/util/http/Parameters.java | 4 ++
|
|
.../util/http/fileupload/FileUploadBase.java | 29 +++++++++++
|
|
.../impl/FileCountLimitExceededException.java | 50 +++++++++++++++++++
|
|
webapps/docs/changelog.xml | 8 +++
|
|
webapps/docs/config/ajp.xml | 15 +++---
|
|
webapps/docs/config/http.xml | 15 +++---
|
|
7 files changed, 119 insertions(+), 14 deletions(-)
|
|
create mode 100644 java/org/apache/tomcat/util/http/fileupload/impl/FileCountLimitExceededException.java
|
|
|
|
diff --git a/java/org/apache/catalina/connector/Request.java b/java/org/apache/catalina/connector/Request.java
|
|
index 889d5e7..87ab732 100644
|
|
--- a/java/org/apache/catalina/connector/Request.java
|
|
+++ b/java/org/apache/catalina/connector/Request.java
|
|
@@ -2769,8 +2769,9 @@ public class Request implements HttpServletRequest {
|
|
}
|
|
}
|
|
|
|
- Parameters parameters = coyoteRequest.getParameters();
|
|
- parameters.setLimit(getConnector().getMaxParameterCount());
|
|
+ int maxParameterCount = getConnector().getMaxParameterCount();
|
|
+ Parameters parameters = coyoteRequest.getParameters();
|
|
+ parameters.setLimit(maxParameterCount);
|
|
|
|
boolean success = false;
|
|
try {
|
|
@@ -2814,6 +2815,13 @@ public class Request implements HttpServletRequest {
|
|
upload.setFileItemFactory(factory);
|
|
upload.setFileSizeMax(mce.getMaxFileSize());
|
|
upload.setSizeMax(mce.getMaxRequestSize());
|
|
+ if (maxParameterCount > -1) {
|
|
+ // There is a limit. The limit for parts needs to be reduced by
|
|
+ // the number of parameters we have already parsed.
|
|
+ // Must be under the limit else parsing parameters would have
|
|
+ // triggered an exception.
|
|
+ upload.setFileCountMax(maxParameterCount - parameters.size());
|
|
+ }
|
|
|
|
parts = new ArrayList<>();
|
|
try {
|
|
diff --git a/java/org/apache/tomcat/util/http/Parameters.java b/java/org/apache/tomcat/util/http/Parameters.java
|
|
index 5bd9ba7..08c6ffd 100644
|
|
--- a/java/org/apache/tomcat/util/http/Parameters.java
|
|
+++ b/java/org/apache/tomcat/util/http/Parameters.java
|
|
@@ -124,6 +124,10 @@ public final class Parameters {
|
|
}
|
|
}
|
|
|
|
+ public int size() {
|
|
+ return parameterCount;
|
|
+ }
|
|
+
|
|
|
|
public void recycle() {
|
|
parameterCount = 0;
|
|
diff --git a/java/org/apache/tomcat/util/http/fileupload/FileUploadBase.java b/java/org/apache/tomcat/util/http/fileupload/FileUploadBase.java
|
|
index eb5a487..5506754 100644
|
|
--- a/java/org/apache/tomcat/util/http/fileupload/FileUploadBase.java
|
|
+++ b/java/org/apache/tomcat/util/http/fileupload/FileUploadBase.java
|
|
@@ -26,6 +26,7 @@ import java.util.Locale;
|
|
import java.util.Map;
|
|
import java.util.NoSuchElementException;
|
|
|
|
+import org.apache.tomcat.util.http.fileupload.impl.FileCountLimitExceededException;
|
|
import org.apache.tomcat.util.http.fileupload.MultipartStream.ItemInputStream;
|
|
import org.apache.tomcat.util.http.fileupload.util.Closeable;
|
|
import org.apache.tomcat.util.http.fileupload.util.FileItemHeadersImpl;
|
|
@@ -131,6 +132,12 @@ public abstract class FileUploadBase {
|
|
* to {@link #sizeMax}. A value of -1 indicates no maximum.
|
|
*/
|
|
private long fileSizeMax = -1;
|
|
+
|
|
+ /**
|
|
+ * The maximum permitted number of files that may be uploaded in a single
|
|
+ * request. A value of -1 indicates no maximum.
|
|
+ */
|
|
+ private long fileCountMax = -1;
|
|
|
|
/**
|
|
* The content encoding to use when reading part headers.
|
|
@@ -208,6 +215,24 @@ public abstract class FileUploadBase {
|
|
this.fileSizeMax = fileSizeMax;
|
|
}
|
|
|
|
+ /**
|
|
+ * Returns the maximum number of files allowed in a single request.
|
|
+ *
|
|
+ * @return The maximum number of files allowed in a single request.
|
|
+ */
|
|
+ public long getFileCountMax() {
|
|
+ return fileCountMax;
|
|
+ }
|
|
+
|
|
+ /**
|
|
+ * Sets the maximum number of files allowed per request/
|
|
+ *
|
|
+ * @param fileCountMax The new limit. {@code -1} means no limit.
|
|
+ */
|
|
+ public void setFileCountMax(long fileCountMax) {
|
|
+ this.fileCountMax = fileCountMax;
|
|
+ }
|
|
+
|
|
/**
|
|
* Retrieves the character encoding used when reading the headers of an
|
|
* individual part. When not specified, or <code>null</code>, the request
|
|
@@ -283,6 +308,10 @@ public abstract class FileUploadBase {
|
|
throw new NullPointerException("No FileItemFactory has been set.");
|
|
}
|
|
while (iter.hasNext()) {
|
|
+ if (items.size() == fileCountMax) {
|
|
+ // The next item will exceed the limit.
|
|
+ throw new FileCountLimitExceededException(ATTACHMENT, getFileCountMax());
|
|
+ }
|
|
final FileItemStream item = iter.next();
|
|
// Don't use getName() here to prevent an InvalidFileNameException.
|
|
final String fileName = ((FileItemIteratorImpl.FileItemStreamImpl) item).name;
|
|
diff --git a/java/org/apache/tomcat/util/http/fileupload/impl/FileCountLimitExceededException.java b/java/org/apache/tomcat/util/http/fileupload/impl/FileCountLimitExceededException.java
|
|
new file mode 100644
|
|
index 0000000..958f681
|
|
--- /dev/null
|
|
+++ b/java/org/apache/tomcat/util/http/fileupload/impl/FileCountLimitExceededException.java
|
|
@@ -0,0 +1,50 @@
|
|
+/*
|
|
+ * 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.
|
|
+ */
|
|
+package org.apache.tomcat.util.http.fileupload.impl;
|
|
+
|
|
+import org.apache.tomcat.util.http.fileupload.FileUploadException;
|
|
+
|
|
+/**
|
|
+ * This exception is thrown if a request contains more files than the specified
|
|
+ * limit.
|
|
+ */
|
|
+public class FileCountLimitExceededException extends FileUploadException {
|
|
+
|
|
+ private static final long serialVersionUID = 2408766352570556046L;
|
|
+
|
|
+ private final long limit;
|
|
+
|
|
+ /**
|
|
+ * Creates a new instance.
|
|
+ *
|
|
+ * @param message The detail message
|
|
+ * @param limit The limit that was exceeded
|
|
+ */
|
|
+ public FileCountLimitExceededException(final String message, final long limit) {
|
|
+ super(message);
|
|
+ this.limit = limit;
|
|
+ }
|
|
+
|
|
+ /**
|
|
+ * Retrieves the limit that was exceeded.
|
|
+ *
|
|
+ * @return The limit that was exceeded by the request
|
|
+ */
|
|
+ public long getLimit() {
|
|
+ return limit;
|
|
+ }
|
|
+}
|
|
diff --git a/webapps/docs/changelog.xml b/webapps/docs/changelog.xml
|
|
index 835b0d0..0268d87 100644
|
|
--- a/webapps/docs/changelog.xml
|
|
+++ b/webapps/docs/changelog.xml
|
|
@@ -44,6 +44,14 @@
|
|
They eventually become mixed with the numbered issues. (I.e., numbered
|
|
issues do not "pop up" wrt. others).
|
|
-->
|
|
+ <subsection name="Other">
|
|
+ <changelog>
|
|
+ <update>
|
|
+ Update the internal fork of Apache Commons FileUpload to 34eb241
|
|
+ (2023-01-03, 2.0-SNAPSHOT). (markt)
|
|
+ </update>
|
|
+ </changelog>
|
|
+ </subsection>
|
|
<section name="Tomcat 9.0.10 (markt)">
|
|
<subsection name="Catalina">
|
|
<changelog>
|
|
diff --git a/webapps/docs/config/ajp.xml b/webapps/docs/config/ajp.xml
|
|
index 622e7ca..38c5269 100644
|
|
--- a/webapps/docs/config/ajp.xml
|
|
+++ b/webapps/docs/config/ajp.xml
|
|
@@ -114,12 +114,15 @@
|
|
</attribute>
|
|
|
|
<attribute name="maxParameterCount" required="false">
|
|
- <p>The maximum number of parameter and value pairs (GET plus POST) which
|
|
- will be automatically parsed by the container. Parameter and value pairs
|
|
- beyond this limit will be ignored. A value of less than 0 means no limit.
|
|
- If not specified, a default of 10000 is used. Note that
|
|
- <code>FailedRequestFilter</code> <a href="filter.html">filter</a> can be
|
|
- used to reject requests that hit the limit.</p>
|
|
+ <p>The maximum total number of request parameters (including uploaded
|
|
+ files) obtained from the query string and, for POST requests, the request
|
|
+ body if the content type is
|
|
+ <code>application/x-www-form-urlencoded</code> or
|
|
+ <code>multipart/form-data</code>. Request parameters beyond this limit
|
|
+ will be ignored. A value of less than 0 means no limit. If not specified,
|
|
+ a default of 10000 is used. Note that <code>FailedRequestFilter</code>
|
|
+ <a href="filter.html">filter</a> can be used to reject requests that
|
|
+ exceed the limit.</p>
|
|
</attribute>
|
|
|
|
<attribute name="maxPostSize" required="false">
|
|
diff --git a/webapps/docs/config/http.xml b/webapps/docs/config/http.xml
|
|
index 3902c9a..52ad063 100644
|
|
--- a/webapps/docs/config/http.xml
|
|
+++ b/webapps/docs/config/http.xml
|
|
@@ -111,12 +111,15 @@
|
|
</attribute>
|
|
|
|
<attribute name="maxParameterCount" required="false">
|
|
- <p>The maximum number of parameter and value pairs (GET plus POST) which
|
|
- will be automatically parsed by the container. Parameter and value pairs
|
|
- beyond this limit will be ignored. A value of less than 0 means no limit.
|
|
- If not specified, a default of 10000 is used. Note that
|
|
- <code>FailedRequestFilter</code> <a href="filter.html">filter</a> can be
|
|
- used to reject requests that hit the limit.</p>
|
|
+ <p>The maximum total number of request parameters (including uploaded
|
|
+ files) obtained from the query string and, for POST requests, the request
|
|
+ body if the content type is
|
|
+ <code>application/x-www-form-urlencoded</code> or
|
|
+ <code>multipart/form-data</code>. Request parameters beyond this limit
|
|
+ will be ignored. A value of less than 0 means no limit. If not specified,
|
|
+ a default of 10000 is used. Note that <code>FailedRequestFilter</code>
|
|
+ <a href="filter.html">filter</a> can be used to reject requests that
|
|
+ exceed the limit.</p>
|
|
</attribute>
|
|
|
|
<attribute name="maxPostSize" required="false">
|
|
--
|
|
2.33.0
|