summaryrefslogtreecommitdiffhomepage
diff options
context:
space:
mode:
authorIgor Sysoev <igor@sysoev.ru>2008-11-27 14:02:52 +0000
committerIgor Sysoev <igor@sysoev.ru>2008-11-27 14:02:52 +0000
commit02269b3f820049e100abd8d8a67a2d79738a42e4 (patch)
tree3753fdcd63369322187fd979d62cf3ab3587233b
parent166dadedda7ffba422b4428a1b1a48556dfa0248 (diff)
downloadnginx-02269b3f820049e100abd8d8a67a2d79738a42e4.tar.gz
nginx-02269b3f820049e100abd8d8a67a2d79738a42e4.tar.bz2
r2039 merge:
add args in redirect to a directory
-rw-r--r--src/http/modules/ngx_http_static_module.c25
1 files changed, 19 insertions, 6 deletions
diff --git a/src/http/modules/ngx_http_static_module.c b/src/http/modules/ngx_http_static_module.c
index b8ad57336..68574fe72 100644
--- a/src/http/modules/ngx_http_static_module.c
+++ b/src/http/modules/ngx_http_static_module.c
@@ -48,7 +48,7 @@ static ngx_int_t
ngx_http_static_handler(ngx_http_request_t *r)
{
u_char *last, *location;
- size_t root;
+ size_t root, len;
ngx_str_t path;
ngx_int_t rc;
ngx_uint_t level;
@@ -144,26 +144,39 @@ ngx_http_static_handler(ngx_http_request_t *r)
return NGX_HTTP_INTERNAL_SERVER_ERROR;
}
- if (!clcf->alias && clcf->root_lengths == NULL) {
+ len = r->uri.len + 1;
+
+ if (!clcf->alias && clcf->root_lengths == NULL && r->args.len == 0) {
location = path.data + clcf->root.len;
+ *last = '/';
+
} else {
- location = ngx_palloc(r->pool, r->uri.len + 1);
+ if (r->args.len) {
+ len += r->args.len + 1;
+ }
+
+ location = ngx_palloc(r->pool, len);
if (location == NULL) {
return NGX_HTTP_INTERNAL_SERVER_ERROR;
}
last = ngx_copy(location, r->uri.data, r->uri.len);
- }
- *last = '/';
+ *last = '/';
+
+ if (r->args.len) {
+ *++last = '?';
+ ngx_memcpy(++last, r->args.data, r->args.len);
+ }
+ }
/*
* we do not need to set the r->headers_out.location->hash and
* r->headers_out.location->key fields
*/
- r->headers_out.location->value.len = r->uri.len + 1;
+ r->headers_out.location->value.len = len;
r->headers_out.location->value.data = location;
return NGX_HTTP_MOVED_PERMANENTLY;