]> git.kaiwu.me - nginx.git/commitdiff
r3313 merge:
authorIgor Sysoev <igor@sysoev.ru>
Mon, 16 Nov 2009 15:16:47 +0000 (15:16 +0000)
committerIgor Sysoev <igor@sysoev.ru>
Mon, 16 Nov 2009 15:16:47 +0000 (15:16 +0000)
nginx sent gzipped responses to clients those do not support gzip,
if "gzip_static on" and "gzip_vary off"; the bug had been introduced in r3250

src/http/modules/ngx_http_gzip_static_module.c

index 8080d9cb08248973a9b2f727f379b9b218a290c5..45ab6aaa26ac6c587b24c272c159bb9bddad2cc4 100644 (file)
@@ -99,9 +99,11 @@ ngx_http_gzip_static_handler(ngx_http_request_t *r)
         return NGX_DECLINED;
     }
 
+    rc = ngx_http_gzip_ok(r);
+
     clcf = ngx_http_get_module_loc_conf(r, ngx_http_core_module);
 
-    if (clcf->gzip_vary && ngx_http_gzip_ok(r) != NGX_OK) {
+    if (!clcf->gzip_vary && rc != NGX_OK) {
         return NGX_DECLINED;
     }
 
@@ -162,6 +164,10 @@ ngx_http_gzip_static_handler(ngx_http_request_t *r)
         return NGX_DECLINED;
     }
 
+    if (rc != NGX_OK) {
+        return NGX_DECLINED;
+    }
+
     ngx_log_debug1(NGX_LOG_DEBUG_HTTP, log, 0, "http static fd: %d", of.fd);
 
     if (of.is_dir) {