当前位置:Gxlcms > PHP教程 > Nginx输出处理过程

Nginx输出处理过程

时间:2021-07-01 10:21:17 帮助过:9人阅读

在HTTP处理过程中我们会不断的见到若干函数先说下
  1. static ngx_int_t ngx_http_echo_handler(ngx_http_request_t *r)
  2. {
  3. ngx_int_t rc;
  4.  ngx_buf_t *b;
  5. //ngx_chain_t是关于ngx_buf_t的一个链表
  6. ngx_chain_t out;
  7. ngx_http_echo_loc_conf_t *elcf; //读取我们写在nginx.conf文件中的配置信息
  8. elcf = ngx_http_get_module_loc_conf(r, ngx_http_echo_module);
  9.  if(!(r->method & (NGX_HTTP_HEAD|NGX_HTTP_GET|NGX_HTTP_POST)))
  10. {
  11. return NGX_HTTP_NOT_ALLOWED;
  12. }
  13. //headers_out我们可以认为是响应头部的处理
  14.  r->headers_out.content_type.len = sizeof("text/html") - 1;
  15.  r->headers_out.content_type.data = (u_char *) "text/html";
  16.  r->headers_out.status = NGX_HTTP_OK;
  17. r->headers_out.content_length_n = elcf->ed.len;
  18. if(r->method == NGX_HTTP_HEAD) {
  19. rc = ngx_http_send_header(r);
  20. if(rc != NGX_OK) {
  21. return rc;
  22. }
  23. }
  24. b = ngx_pcalloc(r->pool, sizeof(ngx_buf_t));
  25. if(b == NULL)
  26. {
  27. ngx_log_error(NGX_LOG_ERR, r->connection->log, 0, "Failed to allocate response buffer.");
  28. return NGX_HTTP_INTERNAL_SERVER_ERROR;
  29. }
  30. //设置ngx_chain_t中的ngx_buf_t链表,next为NULL则说明该链表结束
  31. out.buf = b;
  32. out.next = NULL;
  33. //设置缓存内容
  34. b->pos = elcf->ed.data;
  35. b->last = elcf->ed.data + (elcf->ed.len);
  36.  b->memory = 1;
  37. //当前ngx_buf_t已经是ngx_chain_t链表中的最后一项
  38. b->last_buf = 1;
  39. rc = ngx_http_send_header(r);
  40. if(rc != NGX_OK)
  41. {
  42.  return rc;
  43. }
  44. return ngx_http_output_filter(r, &out);
  45. }

就像我们代码中出现的那样,现在解析两个函数,其一ngx_http_send_request,代码如下

  1. ngx_http_send_header(ngx_http_request_t *r)
  2. {
  3. if (r->header_sent) {
  4. ngx_log_error(NGX_LOG_ALERT, r->connection->log, 0,
  5. "header already sent");
  6. return NGX_ERROR;
  7. }
  8. if (r->err_status) {
  9. r->headers_out.status = r->err_status;
  10. r->headers_out.status_line.len = 0;
  11. }
  12. return ngx_http_top_header_filter(r);
  13. }
这段代码实现的并不直接是发送功能,而是根据过滤模块的ngx_http_top_header_filter链表将请求头部进行处理,接下来就是ngx_http_output_filter函数了,

该函数定义如下:

  1. ngx_int_t
  2. ngx_http_output_filter(ngx_http_request_t *r, ngx_chain_t *in)
  3. {
  4. ngx_int_t rc;
  5. ngx_connection_t *c;
  6. c = r->connection;
  7. ngx_log_debug2(NGX_LOG_DEBUG_HTTP, c->log, 0,
  8. "http output filter \"%V?%V\"", &r->uri, &r->args);
  9. rc = ngx_http_top_body_filter(r, in);
  10. if (rc == NGX_ERROR) {
  11. /* NGX_ERROR may be returned by any filter */
  12. c->error = 1;
  13. }
  14. return rc;
  15. }
可以看到ngx_http_output_filter最终调用的是ngx_http_top_body_filter函数,这里面用到了两个参数,一个是ngx_http_request_t请求,一个是ngx_chain_t链表,其实就是将传递的ngx_chain_t添加到请求的out(也是ngx_chain_t数据类型的)的尾部,在进行输出的时候,将其内容添加到尾部。这样一个页面就输出了


以上就介绍了Nginx 输出处理过程,包括了方面的内容,希望对PHP教程有兴趣的朋友有所帮助。

人气教程排行