diff --git a/src/main/java/spark/CustomErrorPages.java b/src/main/java/spark/CustomErrorPages.java index 1c639c2336..3c62d131d8 100644 --- a/src/main/java/spark/CustomErrorPages.java +++ b/src/main/java/spark/CustomErrorPages.java @@ -31,6 +31,7 @@ public class CustomErrorPages { private static final Logger LOG = LoggerFactory.getLogger(CustomErrorPages.class); public static final String NOT_FOUND = "

404 Not found

"; + public static final String METHOD_NOT_ALLOWED = "

405 Method Not Allowed

"; public static final String INTERNAL_ERROR = "

500 Internal Server Error

"; /** @@ -45,7 +46,7 @@ public static boolean existsFor(int status) { /** * Gets the custom error page for a given status code. If the custom * error page is a route, the output of its handle method is returned. - * If the custom error page is a String, it is returned as an Object. + * If the custom error page is a String, it is returned as an Object. * @param status * @param request * @param response @@ -80,7 +81,7 @@ public String getDefaultFor(int status){ String defaultPage = defaultPages.get(status); return (defaultPage != null) ? defaultPage : "

HTTP Status " + status + "

"; } - + /** * Add a custom error page as a String * @param status @@ -106,6 +107,7 @@ static void add(int status, Route route) { private CustomErrorPages() { customPages = new HashMap<>(); + customPages.put(405, METHOD_NOT_ALLOWED); defaultPages = new HashMap<>(); defaultPages.put(404, NOT_FOUND); defaultPages.put(500, INTERNAL_ERROR); diff --git a/src/main/java/spark/http/matching/MatcherFilter.java b/src/main/java/spark/http/matching/MatcherFilter.java index 8fb908dbdb..05c6cdb75d 100644 --- a/src/main/java/spark/http/matching/MatcherFilter.java +++ b/src/main/java/spark/http/matching/MatcherFilter.java @@ -131,7 +131,6 @@ public void doFilter(ServletRequest servletRequest, try { try { - BeforeFilters.execute(context); Routes.execute(context); AfterFilters.execute(context); @@ -165,14 +164,17 @@ public void doFilter(ServletRequest servletRequest, } if (body.notSet()) { + int returnStatus; + if(httpMethodStr.equals("put") && response.status() == 200) returnStatus = HttpServletResponse.SC_METHOD_NOT_ALLOWED; + else returnStatus = HttpServletResponse.SC_NOT_FOUND; LOG.info("The requested route [{}] has not been mapped in Spark for {}: [{}]", uri, ACCEPT_TYPE_REQUEST_MIME_HEADER, acceptType); - httpResponse.setStatus(HttpServletResponse.SC_NOT_FOUND); + httpResponse.setStatus(returnStatus); - if (CustomErrorPages.existsFor(404)) { + if (CustomErrorPages.existsFor(returnStatus)) { requestWrapper.setDelegate(RequestResponseFactory.create(httpRequest)); responseWrapper.setDelegate(RequestResponseFactory.create(httpResponse)); - body.set(CustomErrorPages.getFor(404, requestWrapper, responseWrapper)); + body.set(CustomErrorPages.getFor(returnStatus, requestWrapper, responseWrapper)); } else { body.set(String.format(CustomErrorPages.NOT_FOUND)); } diff --git a/src/test/java/spark/ResponseBodyTest.java b/src/test/java/spark/ResponseBodyTest.java index f8cf36db0c..e7954e864b 100644 --- a/src/test/java/spark/ResponseBodyTest.java +++ b/src/test/java/spark/ResponseBodyTest.java @@ -34,6 +34,7 @@ public class ResponseBodyTest { public static final String HELLO = "/hello"; + public static final String METHOD_NOT_ALLOWED = "/405"; public static final String SPECIAL = "/special"; public static final String PORAKATIKAOKAO = "/porakatikaokao"; public static final String MAXIME = "/maxime"; @@ -54,6 +55,8 @@ public static void tearDown() { public static void setup() throws IOException { http = new SparkTestUtil(4567); + get(METHOD_NOT_ALLOWED, (q, a) -> HELLO_WORLD); + get(HELLO, (q, a) -> HELLO_WORLD); after(HELLO, (q, a) -> { @@ -105,6 +108,16 @@ public void testHELLO() { } } + @Test + public void testMethodNotAllowed() { + try { + SparkTestUtil.UrlResponse response = http.doMethod("PUT",METHOD_NOT_ALLOWED,""); + assertEquals(405, response.status); + } catch (Throwable e) { + throw new RuntimeException(e); + } + } + @Test public void testSPECIAL() { try {