Be lenient up to 10 (room for 32bit decimals) Bad White Spaces (BWS)
between chunk-size and chunk-ext/CRLF.
git-svn-id: https://svn.apache.org/repos/asf/httpd/httpd/trunk@
1688538 13f79535-47bb-0310-9956-
ffa450edef68
apr_off_t limit;
apr_off_t limit_used;
apr_int32_t chunk_used;
+ apr_int32_t chunk_bws;
apr_int32_t chunkbits;
enum
{
ctx->remaining = 0;
ctx->chunkbits = sizeof(apr_off_t) * 8;
ctx->chunk_used = 0;
+ ctx->chunk_bws = 0;
}
if (c == LF) {
}
}
else if (c == ' ' || c == '\t') {
+ /* Be lenient up to 10 BWS (term from rfc7230 - 3.2.3).
+ */
ctx->state = BODY_CHUNK_CR;
+ if (++ctx->chunk_bws > 10) {
+ return APR_EINVAL;
+ }
}
else if (ctx->state == BODY_CHUNK_CR) {
/*