]> git.kaiwu.me - nginx.git/commitdiff
merge r3092:
authorIgor Sysoev <igor@sysoev.ru>
Mon, 7 Sep 2009 12:03:14 +0000 (12:03 +0000)
committerIgor Sysoev <igor@sysoev.ru>
Mon, 7 Sep 2009 12:03:14 +0000 (12:03 +0000)
handle "/../" case more reliably

src/http/ngx_http_parse.c

index de061c91d7e3466ddacaab75aaa4d49c82cf2a97..5d089302bd1e84bd0fc2410f5eb89751c282d7bf 100644 (file)
@@ -1123,11 +1123,15 @@ ngx_http_parse_complex_uri(ngx_http_request_t *r, ngx_uint_t merge_slashes)
 #endif
             case '/':
                 state = sw_slash;
-                u -= 4;
-                if (u < r->uri.data) {
-                    return NGX_HTTP_PARSE_INVALID_REQUEST;
-                }
-                while (*(u - 1) != '/') {
+                u -= 5;
+                for ( ;; ) {
+                    if (u < r->uri.data) {
+                        return NGX_HTTP_PARSE_INVALID_REQUEST;
+                    }
+                    if (*u == '/') {
+                        u++;
+                        break;
+                    }
                     u--;
                 }
                 break;