Skip to content

Commit

Permalink
Detect Jetty 12 "max length exceeded" message in handleParseFailure
Browse files Browse the repository at this point in the history
Closes gh-31850
  • Loading branch information
jhoeller committed Dec 18, 2023
1 parent 24f8eac commit 045c5dc
Show file tree
Hide file tree
Showing 2 changed files with 55 additions and 6 deletions.
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
/*
* Copyright 2002-2022 the original author or authors.
* Copyright 2002-2023 the original author or authors.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
Expand Down Expand Up @@ -112,13 +112,21 @@ private void parseRequest(HttpServletRequest request) {
}

protected void handleParseFailure(Throwable ex) {
String msg = ex.getMessage();
if (msg != null) {
msg = msg.toLowerCase();
if (msg.contains("size") && msg.contains("exceed")) {
throw new MaxUploadSizeExceededException(-1, ex);
// MaxUploadSizeExceededException ?
Throwable cause = ex;
do {
String msg = cause.getMessage();
if (msg != null) {
msg = msg.toLowerCase();
if (msg.contains("exceed") && (msg.contains("size") || msg.contains("length"))) {
throw new MaxUploadSizeExceededException(-1, ex);
}
}
cause = cause.getCause();
}
while (cause != null);

// General MultipartException
throw new MultipartException("Failed to parse multipart servlet request", ex);
}

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -18,23 +18,29 @@

import java.io.IOException;
import java.nio.charset.StandardCharsets;
import java.util.Collection;

import jakarta.servlet.ServletException;
import jakarta.servlet.http.Part;
import org.junit.jupiter.api.Test;

import org.springframework.http.converter.FormHttpMessageConverter;
import org.springframework.util.LinkedMultiValueMap;
import org.springframework.util.MultiValueMap;
import org.springframework.web.multipart.MaxUploadSizeExceededException;
import org.springframework.web.multipart.MultipartFile;
import org.springframework.web.testfixture.http.MockHttpOutputMessage;
import org.springframework.web.testfixture.servlet.MockHttpServletRequest;
import org.springframework.web.testfixture.servlet.MockPart;

import static org.assertj.core.api.Assertions.assertThat;
import static org.assertj.core.api.Assertions.assertThatExceptionOfType;

/**
* Unit tests for {@link StandardMultipartHttpServletRequest}.
*
* @author Rossen Stoyanchev
* @author Juergen Hoeller
*/
class StandardMultipartHttpServletRequestTests {

Expand Down Expand Up @@ -92,6 +98,31 @@ void multipartFileResource() throws IOException {
""".replace("\n", "\r\n"));
}

@Test
void plainSizeExceededServletException() {
ServletException ex = new ServletException("Request size exceeded");

assertThatExceptionOfType(MaxUploadSizeExceededException.class)
.isThrownBy(() -> requestWithException(ex)).withCause(ex);
}

@Test // gh-28759
void jetty94MaxRequestSizeException() {
ServletException ex = new ServletException(new IllegalStateException("Request exceeds maxRequestSize"));

assertThatExceptionOfType(MaxUploadSizeExceededException.class)
.isThrownBy(() -> requestWithException(ex)).withCause(ex);
}

@Test // gh-31850
void jetty12MaxLengthExceededException() {
ServletException ex = new ServletException(new RuntimeException("400: bad multipart",
new IllegalStateException("max length exceeded")));

assertThatExceptionOfType(MaxUploadSizeExceededException.class)
.isThrownBy(() -> requestWithException(ex)).withCause(ex);
}


private static StandardMultipartHttpServletRequest requestWithPart(String name, String disposition, String content) {
MockHttpServletRequest request = new MockHttpServletRequest();
Expand All @@ -101,4 +132,14 @@ private static StandardMultipartHttpServletRequest requestWithPart(String name,
return new StandardMultipartHttpServletRequest(request);
}

private static StandardMultipartHttpServletRequest requestWithException(ServletException ex) {
MockHttpServletRequest request = new MockHttpServletRequest() {
@Override
public Collection<Part> getParts() throws ServletException {
throw ex;
}
};
return new StandardMultipartHttpServletRequest(request);
}

}

0 comments on commit 045c5dc

Please sign in to comment.