在HTTP處理過程中我們會不斷的見到若干函數先說下
static ngx_int_t ngx_http_echo_handler(ngx_http_request_t *r) { ngx_int_t rc; ngx_buf_t *b; //ngx_chain_t是关于ngx_buf_t的一个链表 ngx_chain_t out; ngx_http_echo_loc_conf_t *elcf; //读取我们写在nginx.conf文件中的配置信息 elcf = ngx_http_get_module_loc_conf(r, ngx_http_echo_module); if(!(r->method & (NGX_HTTP_HEAD|NGX_HTTP_GET|NGX_HTTP_POST))) { return NGX_HTTP_NOT_ALLOWED; } //headers_out我们可以认为是响应头部的处理 r->headers_out.content_type.len = sizeof("text/html") - 1; r->headers_out.content_type.data = (u_char *) "text/html"; r->headers_out.status = NGX_HTTP_OK; r->headers_out.content_length_n = elcf->ed.len; if(r->method == NGX_HTTP_HEAD) { rc = ngx_http_send_header(r); if(rc != NGX_OK) { return rc; } } b = ngx_pcalloc(r->pool, sizeof(ngx_buf_t)); if(b == NULL) { ngx_log_error(NGX_LOG_ERR, r->connection->log, 0, "Failed to allocate response buffer."); return NGX_HTTP_INTERNAL_SERVER_ERROR; } //设置ngx_chain_t中的ngx_buf_t链表,next为NULL则说明该链表结束 out.buf = b; out.next = NULL; //设置缓存内容 b->pos = elcf->ed.data; b->last = elcf->ed.data + (elcf->ed.len); b->memory = 1; //当前ngx_buf_t已经是ngx_chain_t链表中的最后一项 b->last_buf = 1; rc = ngx_http_send_header(r); if(rc != NGX_OK) { return rc; } return ngx_http_output_filter(r, &out); }
就像我們程式碼中出現的那樣,現在解析兩個函數,其一ngx_http_send_request,程式碼如下
ngx_http_send_header(ngx_http_request_t *r) { if (r->header_sent) { ngx_log_error(NGX_LOG_ALERT, r->connection->log, 0, "header already sent"); return NGX_ERROR; } if (r->err_status) { r->headers_out.status = r->err_status; r->headers_out.status_line.len = 0; } return ngx_http_top_header_filter(r); }這段程式碼實現的並不直接是發送功能,而是根據過濾模組的ngx_http_top_header_filter鍊錶將請求頭部進行處理,接下來就是ngx_http_output_filter函數了,
該函數定義如下:
ngx_int_t ngx_http_output_filter(ngx_http_request_t *r, ngx_chain_t *in) { ngx_int_t rc; ngx_connection_t *c; c = r->connection; ngx_log_debug2(NGX_LOG_DEBUG_HTTP, c->log, 0, "http output filter \"%V?%V\"", &r->uri, &r->args); rc = ngx_http_top_body_filter(r, in); if (rc == NGX_ERROR) { /* NGX_ERROR may be returned by any filter */ c->error = 1; } return rc; }可以看到ngx_http_output_filter到了兩個參數,一個是ngx_http_request_t請求,一個是ngx_chain_t鍊錶,其實就是將傳遞的ngx_chain_t加到請求的out(也是ngx_chain_t資料型別的)的尾部,在進行輸出的時候,將其內容加到尾部。這樣一個頁面就輸出了
以上就介紹了Nginx 輸出處理過程,包括了方面的內容,希望對PHP教程有興趣的朋友有所幫助。