浏览代码

Return error for incomplete multipart form data (#682)

bel2125 6 年之前
父节点
当前提交
e2e0f08a6c
共有 1 个文件被更改,包括 8 次插入0 次删除
  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. */