在之前的工作中,我使用ngx_http_send_header和ngx_http_output_filter响应客户端。但是在实际的测试中遇到很多问题,例如ngx_http_output_filter在某些时候常常返回NGX_ERROR或是NGX_AGAIN。所以我不得不深入这个函数,找出其中的原因。


一哥们的博文《ngx的filter处理》(http://simohayha.iteye.com/blog/642314)介绍了filter的工作原理。

但还不能用于解决我的问题。这篇文章中说, ngx_http_write_filter_module和ngx_http_header_filter_module

分别是body filter和header filter的第一个初始化模块。这个模块完成了发送数据的主要任务。

在文件ngx_http_write_filter_module.c中,有函数ngx_http_write_filter。

ngx_http_write_filter(ngx_http_request *r, ngx_chain_t *in ) {

……

chain->send_chain(c,c->out,limit);//这句代码完成了发送数据的任务

…….

}

而这个回调函数在哪里呢?

#if (NGX_HAVE_SENDFILE)
ngx_linux_sendfile_chain,
NGX_IO_SENDFILE
#else
ngx_writev_chain,
0
#endif

由上边的代码可知,如果启用了sendfile, chain->send_chain与前者对应,否则就是后者。

在我的开发环境中似乎是在文件ngx_linux_sendfile_chain.c中的函数:

ngx_linux_sendfile_chain(ngx_connection_t *c, ngx_chain_t *in, off_t *limit) {

。。。。

}

///代码读到这里,我顿悟了

为什么非得使用nginx自己定义的函数呢?为什么一定要了解那些复杂的层层嵌套呢?为什么

不直接利用socket发送需要传输的内容呢?源代码,去屎吧!我再也不管代码结构是否美观了,

只要功能出来即可!

///

虽说要抛开nginx自带的HTTP响应函数,但是,我还是要了解结构ngx_http_request_t  *r中一些字段的

含义。这样才可以提取出自己需要的信息。

r->headers_out保存了关于一些关于服务器回复客户端的HTTP头的信息。下面,我们来关注一下

ngx_http_headers_out_t这个结构。

在ngx_http_request.h这个文件中,定义了此结构

typedef struct {

……
ngx_uint_t status;//此处保存了回复客户端的状态码,直接使用即可

ngx_table_elt_t *server;//此处保存了

ngx_table_elt_t *date;//

}

其中ngx_table_elt_t的定义如下:

typedef struct {

ngx_uint_t hash;

ngx_str_t   key;

ngx_str_t   value;

u_cahr       *lowcase_key;

}

其中ngx_str_t的定义如下:

typedef struct {

size_t    len;

u_char  *data;

} ngx_str_t

/不对,我需要的信息不在此结构中///

ngx_http_headers_out_t这个结构的内容应当在filter中被填充,而目前,我添加代码

的地方还没有进行到这一步,看来我将不得不研究一下此过程中涉及到的所有filter。

只好放弃先前思路,正是:几行代码无我份,一场辛苦为谁忙。