Welcome! Log In Create A New Profile

Advanced

[nginx] svn commit: r5093 - trunk/src/http

Anonymous User
February 27, 2013 12:28PM
Author: vbart
Date: 2013-02-27 17:27:15 +0000 (Wed, 27 Feb 2013)
New Revision: 5093
URL: http://trac.nginx.org/nginx/changeset/5093/nginx

Log:
Apply server configuration as soon as host is known.

Previously, this was done only after the whole request header
was parsed, and if an error occurred earlier then the request
was processed in the default server (or server chosen by SNI),
while r->headers_in.server might be set to the value from the
Host: header or host from request line.

r->headers_in.server is in turn used for $host variable and
in HTTP redirects if "server_name_in_redirect" is disabled.
Without the change, configurations that rely on this during
error handling are potentially unsafe if SNI is used.

This change also allows to use server specific settings of
"underscores_in_headers", "ignore_invalid_headers", and
"large_client_header_buffers" directives for HTTP requests
and HTTPS requests without SNI.


Modified:
trunk/src/http/ngx_http_request.c

Modified: trunk/src/http/ngx_http_request.c
===================================================================
--- trunk/src/http/ngx_http_request.c 2013-02-27 17:21:21 UTC (rev 5092)
+++ trunk/src/http/ngx_http_request.c 2013-02-27 17:27:15 UTC (rev 5093)
@@ -919,13 +919,18 @@
return;
}

+ if (ngx_http_set_virtual_server(r, &host) == NGX_ERROR) {
+ return;
+ }
+
r->headers_in.server = host;
}

if (r->http_version < NGX_HTTP_VERSION_10) {

- if (ngx_http_set_virtual_server(r, &r->headers_in.server)
- == NGX_ERROR)
+ if (r->headers_in.server.len == 0
+ && ngx_http_set_virtual_server(r, &r->headers_in.server)
+ == NGX_ERROR)
{
return;
}
@@ -1014,7 +1019,6 @@
}

cmcf = ngx_http_get_module_main_conf(r, ngx_http_core_module);
- cscf = ngx_http_get_module_srv_conf(r, ngx_http_core_module);

rc = NGX_AGAIN;

@@ -1068,6 +1072,9 @@
}
}

+ /* the host header could change the server configuration context */
+ cscf = ngx_http_get_module_srv_conf(r, ngx_http_core_module);
+
rc = ngx_http_parse_header_line(r, r->header_in,
cscf->underscores_in_headers);

@@ -1444,6 +1451,10 @@
return NGX_OK;
}

+ if (ngx_http_set_virtual_server(r, &host) == NGX_ERROR) {
+ return NGX_ERROR;
+ }
+
r->headers_in.server = host;

return NGX_OK;
@@ -1570,7 +1581,10 @@
static ngx_int_t
ngx_http_process_request_header(ngx_http_request_t *r)
{
- if (ngx_http_set_virtual_server(r, &r->headers_in.server) == NGX_ERROR) {
+ if (r->headers_in.server.len == 0
+ && ngx_http_set_virtual_server(r, &r->headers_in.server)
+ == NGX_ERROR)
+ {
return NGX_ERROR;
}


_______________________________________________
nginx-devel mailing list
nginx-devel@nginx.org
http://mailman.nginx.org/mailman/listinfo/nginx-devel
Subject Author Views Posted

[nginx] svn commit: r5093 - trunk/src/http

Anonymous User 882 February 27, 2013 12:28PM



Sorry, you do not have permission to post/reply in this forum.

Online Users

Guests: 244
Record Number of Users: 8 on April 13, 2023
Record Number of Guests: 421 on December 02, 2018
Powered by nginx      Powered by FreeBSD      PHP Powered      Powered by MariaDB      ipv6 ready