Explorar o código

Return error for incomplete multipart form data (#682)

bel2125 %!s(int64=6) %!d(string=hai) anos
pai
achega
e2e0f08a6c
Modificáronse 1 ficheiros con 8 adicións e 0 borrados
  1. 8 0
      src/handle_form.inl

+ 8 - 0
src/handle_form.inl

@@ -873,6 +873,14 @@ mg_handle_form_request(struct mg_connection *conn,
 				/* Set "towrite" to the number of bytes available
 				 * in the buffer */
 				towrite = (size_t)(buf - hend + buf_fill);
+
+				if (towrite < bl + 4) {
+					/* Not enough data stored. */
+					/* Incomplete request. */
+					mg_free(boundary);
+					return -1;
+				}
+
 				/* Subtract the boundary length, to deal with
 				 * cases the boundary is only partially stored
 				 * in the buffer. */