aboutsummaryrefslogtreecommitdiff
path: root/pdf-as-web/src/main/java/at
diff options
context:
space:
mode:
authorJakob Heher <jakob.heher@iaik.tugraz.at>2026-06-09 16:06:32 +0200
committerGitHub <noreply@github.com>2026-06-09 16:06:32 +0200
commit68165ce0bb979891fbbb6db7eb3d58c31aa1223a (patch)
tree289148f9a1bfc502c3d8fff9e7fd1ebaaf4158b3 /pdf-as-web/src/main/java/at
parentfc8a4ad6228632636003c65ec6c005eff5cd03d6 (diff)
downloadpdf-as-4-68165ce0bb979891fbbb6db7eb3d58c31aa1223a.tar.gz
pdf-as-4-68165ce0bb979891fbbb6db7eb3d58c31aa1223a.tar.bz2
pdf-as-4-68165ce0bb979891fbbb6db7eb3d58c31aa1223a.zip
fix ExceptionCatchFilter consuming multipart bodies incorrectly (#92)
Diffstat (limited to 'pdf-as-web/src/main/java/at')
-rw-r--r--pdf-as-web/src/main/java/at/gv/egiz/pdfas/web/filter/ExceptionCatchFilter.java28
1 files changed, 16 insertions, 12 deletions
diff --git a/pdf-as-web/src/main/java/at/gv/egiz/pdfas/web/filter/ExceptionCatchFilter.java b/pdf-as-web/src/main/java/at/gv/egiz/pdfas/web/filter/ExceptionCatchFilter.java
index dc85936a..a597c222 100644
--- a/pdf-as-web/src/main/java/at/gv/egiz/pdfas/web/filter/ExceptionCatchFilter.java
+++ b/pdf-as-web/src/main/java/at/gv/egiz/pdfas/web/filter/ExceptionCatchFilter.java
@@ -38,6 +38,7 @@ import jakarta.servlet.http.HttpServletRequest;
import jakarta.servlet.http.HttpServletResponse;
import jakarta.servlet.http.HttpSession;
+import org.apache.commons.fileupload2.jakarta.servlet6.JakartaServletFileUpload;
import org.apache.commons.lang3.StringUtils;
import org.slf4j.MDC;
@@ -90,22 +91,25 @@ public class ExceptionCatchFilter implements Filter {
throws IOException, ServletException {
try {
- if (request instanceof HttpServletRequest) {
- HttpServletRequest httpRequest = (HttpServletRequest) request;
-
- HttpSession session = httpRequest.getSession(isStatefull(httpRequest.getServletPath()));
+ if (request instanceof HttpServletRequest httpRequest) {
+
+ HttpSession session = httpRequest.getSession(isStatefull(httpRequest.getServletPath()));
String sessionId = session != null ? session.getId() : "-";
MDC.put("SESSION_ID", sessionId);
log.info("Access from IP: {}", getClientIpAddr(httpRequest));
log.info("Access to: {} in Session: {}", httpRequest.getServletPath(), sessionId);
-
- log.debug("Processing Parameters into Attributes");
- @SuppressWarnings("unchecked")
- Enumeration<String> parameterNames = httpRequest.getParameterNames();
- while (parameterNames.hasMoreElements()) {
- String name = parameterNames.nextElement();
- String value = httpRequest.getParameter(name);
- request.setAttribute(name, value);
+
+ if (!JakartaServletFileUpload.isMultipartContent(httpRequest)) {
+ log.debug("Processing Parameters into Attributes");
+ @SuppressWarnings("unchecked")
+ Enumeration<String> parameterNames = httpRequest.getParameterNames();
+ while (parameterNames.hasMoreElements()) {
+ String name = parameterNames.nextElement();
+ String value = httpRequest.getParameter(name);
+ request.setAttribute(name, value);
+ }
+ } else {
+ log.debug("Skipping global parameter parsing for multipart request");
}
}