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
|