这段时间做了一个web的项目,要求在日志中输出自定义的http header字段token和have-deleted的值,

nginx版本为1.1.19,以下是具体的log配置:

log_format  main      '$remote_addr - $remote_user [$time_local] $http_token 
                      $http_have_deleted "$request" '
                      '$status $request_time $body_bytes_sent "$http_referer" '
                      '"$http_user_agent" "$http_x_forwarded_for"';

通过配置可以看出,可在自定义header字段前加http_,即可将指定的自定义header字段打印到log中。

像have-deleted这种带横线的字段,需要写成have_deleted,nginx会自动做处理的。


有一点需要注意:我的nginx版本是1.1.19!!!


我写这篇博客的时候,nginx最新版本是1.9.7,根据官方文档说明,要想打印自定义的header字段,需要在字段前加sent_http_,所以一定要注意nginx的版本!!

最后附上nginx1.9.7的文档:

http://nginx.org/en/docs/http/ngx_http_log_module.html