Fixed handling of very long locations (ticket #2435).

Previously, location prefix length in ngx_http_location_tree_node_t was
stored as "u_char", and therefore location prefixes longer than 255 bytes
were handled incorrectly.

Fix is to use "u_short" instead.  With "u_short", prefixes up to 65535 bytes
can be safely used, and this isn't reachable due to NGX_CONF_BUFFER, which
is 4096 bytes.
This commit is contained in:
Maxim Dounin 2023-01-26 03:34:44 +03:00
parent 2a56f86948
commit b0ff65f27f
2 changed files with 2 additions and 2 deletions

View file

@ -1130,7 +1130,7 @@ ngx_http_create_locations_tree(ngx_conf_t *cf, ngx_queue_t *locations,
node->auto_redirect = (u_char) ((lq->exact && lq->exact->auto_redirect) node->auto_redirect = (u_char) ((lq->exact && lq->exact->auto_redirect)
|| (lq->inclusive && lq->inclusive->auto_redirect)); || (lq->inclusive && lq->inclusive->auto_redirect));
node->len = (u_char) len; node->len = (u_short) len;
ngx_memcpy(node->name, &lq->name->data[prefix], len); ngx_memcpy(node->name, &lq->name->data[prefix], len);
ngx_queue_split(locations, q, &tail); ngx_queue_split(locations, q, &tail);

View file

@ -463,8 +463,8 @@ struct ngx_http_location_tree_node_s {
ngx_http_core_loc_conf_t *exact; ngx_http_core_loc_conf_t *exact;
ngx_http_core_loc_conf_t *inclusive; ngx_http_core_loc_conf_t *inclusive;
u_short len;
u_char auto_redirect; u_char auto_redirect;
u_char len;
u_char name[1]; u_char name[1];
}; };