]> git.kaiwu.me - nginx.git/commitdiff
Merge of r5013: proxy: fixed proxy_method to always add space.
authorMaxim Dounin <mdounin@mdounin.ru>
Mon, 11 Feb 2013 15:31:10 +0000 (15:31 +0000)
committerMaxim Dounin <mdounin@mdounin.ru>
Mon, 11 Feb 2013 15:31:10 +0000 (15:31 +0000)
Before the patch if proxy_method was specified at http{} level the code
to add trailing space wasn't executed, resulting in incorrect requests
to upstream.

src/http/modules/ngx_http_proxy_module.c

index 455f27aec6bc91a09b9057857ab6b073e4d29caa..977bed73c76c0c2266774f2f16a4f5146982acff 100644 (file)
@@ -2608,7 +2608,7 @@ ngx_http_proxy_create_loc_conf(ngx_conf_t *cf)
      *     conf->upstream.store_lengths = NULL;
      *     conf->upstream.store_values = NULL;
      *
-     *     conf->method = NULL;
+     *     conf->method = { 0, NULL };
      *     conf->headers_source = NULL;
      *     conf->headers_set_len = NULL;
      *     conf->headers_set = NULL;
@@ -2907,10 +2907,11 @@ ngx_http_proxy_merge_loc_conf(ngx_conf_t *cf, void *parent, void *child)
 
 #endif
 
-    if (conf->method.len == 0) {
-        conf->method = prev->method;
+    ngx_conf_merge_str_value(conf->method, prev->method, "");
 
-    } else {
+    if (conf->method.len
+        && conf->method.data[conf->method.len - 1] != ' ')
+    {
         conf->method.data[conf->method.len] = ' ';
         conf->method.len++;
     }