From: Igor Sysoev Date: Tue, 7 Apr 2009 15:50:08 +0000 (+0000) Subject: fix r2590: error_page made an external redirect without query string X-Git-Tag: release-0.7.51~12 X-Git-Url: http://git.kaiwu.me/%7B@url%7D?a=commitdiff_plain;h=64851bb2aeef37a708ca34f74280c05cd38ad969;p=nginx.git fix r2590: error_page made an external redirect without query string --- diff --git a/src/http/ngx_http_core_module.c b/src/http/ngx_http_core_module.c index ffdd0b044..b6f4b11e1 100644 --- a/src/http/ngx_http_core_module.c +++ b/src/http/ngx_http_core_module.c @@ -3875,7 +3875,7 @@ ngx_http_core_error_page(ngx_conf_t *cf, ngx_command_t *cmd, void *conf) args.len = 0; args.data = NULL; - if (cv.lengths == NULL) { + if (cv.lengths == NULL && uri.data[0] == '/') { p = (u_char *) ngx_strchr(uri.data, '?'); if (p) { diff --git a/src/http/ngx_http_special_response.c b/src/http/ngx_http_special_response.c index 38d0d393c..f50f1056e 100644 --- a/src/http/ngx_http_special_response.c +++ b/src/http/ngx_http_special_response.c @@ -451,14 +451,14 @@ ngx_http_send_error_page(ngx_http_request_t *r, ngx_http_err_page_t *err_page) return NGX_ERROR; } - if (err_page->value.lengths) { - ngx_http_split_args(r, &uri, &args); + if (uri.data[0] == '/') { - } else { - args = err_page->args; - } + if (err_page->value.lengths) { + ngx_http_split_args(r, &uri, &args); - if (uri.data[0] == '/') { + } else { + args = err_page->args; + } if (r->method != NGX_HTTP_HEAD) { r->method = NGX_HTTP_GET;