ПРОЕКТЫ 


  АРХИВ 


Apache-Talk @lexa.ru 

Inet-Admins @info.east.ru 

Filmscanners @halftone.co.uk 

Security-alerts @yandex-team.ru 

nginx-ru @sysoev.ru 


  СТАТЬИ 


  ПЕРСОНАЛЬНОЕ 


  ПРОГРАММЫ 



ПИШИТЕ
ПИСЬМА












     АРХИВ :: nginx-ru
Nginx-ru mailing list archive (nginx-ru@sysoev.ru)

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

Re: отключить возможность д окачки?



On Tue, May 31, 2011 at 03:04:29AM +0700, Kirill Morozov wrote:
> 2009/9/8 Igor Sysoev <is@xxxxxxxxxxxxx>
> 
> > On Tue, Sep 08, 2009 at 01:51:31PM +0400, ilya@xxxxxxxxxxxxxx wrote:
> >
> > > Чтобы докачка не работала, можно просто удалить из заголовка поле
> > > content-length. Тогда даунлоад менеджеры будут качать в один поток.
> >
> > Правильнее из ответа удалять "Accept-Ranges: bytes", но сейчас этого
> > сделать нельзя.
> >
> 
> > --
> > Игорь Сысоев
> > http://sysoev.ru
> >
> >
> Заранее извиняюсь, что поднимаю такое старое обсуждение. Игорь, не появилась
> ли сейчас возможность убрать "Accept-Ranges: bytes" из заголовков, не
> прибегая к использованию внешних модулей вроде
> http://wiki.nginx.org/NginxHttpHeadersMoreModule ???
> 
> Задача простая - дать пользователю скачать файл ровно один раз, а дальше
> через post_action он помечается в бд как скачанный.

Прилагаемый патч должен помочь.


-- 
Igor Sysoev
Index: src/http/modules/ngx_http_headers_filter_module.c
===================================================================
--- src/http/modules/ngx_http_headers_filter_module.c   (revision 3934)
+++ src/http/modules/ngx_http_headers_filter_module.c   (working copy)
@@ -52,6 +52,8 @@
     ngx_http_header_val_t *hv, ngx_str_t *value);
 static ngx_int_t ngx_http_set_last_modified(ngx_http_request_t *r,
     ngx_http_header_val_t *hv, ngx_str_t *value);
+static ngx_int_t ngx_http_set_accept_ranges(ngx_http_request_t *r,
+    ngx_http_header_val_t *hv, ngx_str_t *value);
 
 static void *ngx_http_headers_create_conf(ngx_conf_t *cf);
 static char *ngx_http_headers_merge_conf(ngx_conf_t *cf,
@@ -71,6 +73,10 @@
                  offsetof(ngx_http_headers_out_t, last_modified),
                  ngx_http_set_last_modified },
 
+    { ngx_string("Accept-Ranges"),
+                 offsetof(ngx_http_headers_out_t, accept_ranges),
+                 ngx_http_set_accept_ranges },
+
     { ngx_null_string, 0, NULL }
 };
 
@@ -399,6 +405,49 @@
 }
 
 
+static ngx_int_t
+ngx_http_set_accept_ranges(ngx_http_request_t *r, ngx_http_header_val_t *hv,
+    ngx_str_t *value)
+{
+    ngx_table_elt_t  *h, **old;
+
+    if (hv->offset) {
+        old = (ngx_table_elt_t **) ((char *) &r->headers_out + hv->offset);
+
+    } else {
+        old = NULL;
+    }
+
+    r->allow_ranges = 0;
+
+    if (old == NULL || *old == NULL) {
+
+        if (value->len == 0) {
+            return NGX_OK;
+        }
+
+        h = ngx_list_push(&r->headers_out.headers);
+        if (h == NULL) {
+            return NGX_ERROR;
+        }
+
+    } else {
+        h = *old;
+
+        if (value->len == 0) {
+            h->hash = 0;
+            return NGX_OK;
+        }
+    }
+
+    h->hash = hv->hash;
+    h->key = hv->key;
+    h->value = *value;
+
+    return NGX_OK;
+}
+
+
 static void *
 ngx_http_headers_create_conf(ngx_conf_t *cf)
 {
_______________________________________________
nginx-ru mailing list
nginx-ru@xxxxxxxxx
http://nginx.org/mailman/listinfo/nginx-ru


 




Copyright © Lexa Software, 1996-2009.