ngx_http_top_header_filter

./nginx-1.24.0/src/http/ngx_http.h

extern ngx_http_output_header_filter_pt  ngx_http_top_header_filter;

这段代码来自于 Nginx 源码(ngx_http.h 或相关头文件),它声明了一个全局函数指针变量,用于实现 Nginx 的 HTTP 响应头过滤链(Header Filter Chain)机制。


1. 代码含义

extern ngx_http_output_header_filter_pt  ngx_http_top_header_filter;
  • extern:
    声明该变量在其他文件中定义,表示此处仅引用该全局变量。

  • ngx_http_output_header_filter_pt:
    这是一个函数指针类型,定义如下(简化):

    typedef ngx_int_t (*ngx_http_output_header_filter_pt)(ngx_http_request_t *r);
    

    它指向一个函数,该函数接收 ngx_http_request_t*(HTTP 请求结构体),返回 ngx_int_t(通常表示成功或错误码)。

  • ngx_http_top_header_filter:
    全局变量,保存当前头部过滤链的入口函数指针


2. Nginx 过滤链机制

Nginx 的 HTTP 响应处理分为头部过滤链主体过滤链,通过模块化的方式允许各模块按顺序处理响应。

  • 头部过滤链
    负责处理 HTTP 响应头(如修改 Content-Type、添加/删除头部字段等)。
  • 链式调用
    每个模块可以注册自己的过滤函数,Nginx 通过 ngx_http_top_header_filter 指向链表的头部,依次调用各模块的过滤函数。

3. 工作原理

  1. 初始化阶段
    Nginx 在启动时,各模块通过 ngx_http_next_header_filter 将自身的过滤函数插入链中。
    例如,ngx_http_not_modified_filter_module 会检查 If-Modified-Since 头。

  2. 运行时调用
    当 Nginx 准备发送响应头时,调用 ngx_http_send_header(r),内部会触发:

    ngx_http_top_header_filter(r);
    

    该函数指针会依次调用链上所有模块的头部过滤函数,直到某个函数返回错误或链结束。

  3. 模块自定义过滤函数
    每个模块的过滤函数通常如下结构:

    static ngx_int_t ngx_http_foo_header_filter(ngx_http_request_t *r) {
        // 处理响应头...
        return ngx_http_next_header_filter(r); // 调用下一个过滤函数
    }
    

4. 实际应用示例

假设有三个模块注册了头部过滤函数,链的顺序为:
A → B → C(通过模块初始化时的插入顺序决定)。
调用 ngx_http_top_header_filter(r) 的流程:

  1. A 处理响应头,调用 next(指向 B)。
  2. B 处理响应头,调用 next(指向 C)。
  3. C 处理响应头,调用 next(可能指向最终的发送函数)。

5. 关键点总结

  • 模块化设计
    允许各模块灵活修改响应头,无需修改核心代码。
  • 责任链模式
    通过函数指针链实现模块的协同处理。
  • 性能优化
    过滤链的线性调用确保高效处理(无动态查找开销)。

ngx_http_top_header_filter 的来源:

src\http\ngx_http_header_filter_module.c

ngx_http_header_filter_module 模块的
postconfiguration 是
ngx_http_header_filter_init

static ngx_int_t
ngx_http_header_filter_init(ngx_conf_t *cf)
{
    ngx_http_top_header_filter = ngx_http_header_filter;

    return NGX_OK;
}

这里 ngx_http_top_header_filter 被赋值为 ngx_http_header_filter


ngx_http_header_filter

static ngx_int_t ngx_http_flv_live_init(ngx_conf_t *cf) { ngx_str_t *value; ngx_array_t a; ngx_http_handler_pt *h; ngx_http_flv_live_fmt_t *fmt; ngx_http_flv_live_main_conf_t *lmcf; ngx_http_core_main_conf_t *cmcf; lmcf = ngx_http_conf_get_module_main_conf(cf, ngx_http_flv_live_module); if (lmcf->combined_used) { if (ngx_array_init(&a, cf->pool, 1, sizeof(ngx_str_t)) != NGX_OK) { return NGX_ERROR; } value = ngx_array_push(&a); if (value == NULL) { return NGX_ERROR; } *value = ngx_http_combined_fmt; fmt = lmcf->formats.elts; if (ngx_http_flv_live_compile_format(cf, NULL, fmt->ops, &a, 0) != NGX_CONF_OK) { return NGX_ERROR; } } cmcf = ngx_http_conf_get_module_main_conf(cf, ngx_http_core_module); h = ngx_array_push(&cmcf->phases[NGX_HTTP_LOG_PHASE].handlers); if (h == NULL) { return NGX_ERROR; } *h = ngx_http_flv_live_handler; ngx_http_next_body_filter = ngx_http_top_body_filter; ngx_http_top_body_filter = ngx_http_flv_parser_body_filter; return NGX_OK; } static ngx_http_module_t ngx_http_flv_live_module_ctx = { NULL, /* preconfiguration */ ngx_http_flv_live_init, /* postconfiguration */ ngx_http_flv_live_create_main_conf, /* create main configuration */ NULL, /* init main configuration */ NULL, /* create server configuration */ NULL, /* merge server configuration */ ngx_http_flv_live_create_loc_conf, /* create location configuration */ ngx_http_flv_live_merge_loc_conf /* merge location configuration */ }; ngx_module_t ngx_http_flv_live_module = { NGX_MODULE_V1, &ngx_http_flv_live_module_ctx, /* module context */ ngx_http_flv_live_commands, /* module directives */ NGX_HTTP_MODULE, /* module type */ NULL, /* init master */ NULL, /* init module */ NULL, /* init process */ NULL, /* init thread */ NULL, /* exit thread */ NULL, /* exit process */ NULL, /* exit master */ NGX_MODULE_V1_PADDING };
最新发布
08-28
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值