在应用系统中,有时将请求的用户信息和身份认证信息放到请求头中,服务器认证通过后,通过cookie返回客户端一个标识,在后续的请求时,客户端需要带上这个cookie,通过这个cookie,服务器就知道请求的用户信息了,没有必要每次请求都携带用户信息和认证信息。
1. 日志格式自定义
自定义需要的日志格式。
log_format custom_log '$remote_addr - $remote_user [$time_local] "$request" '
'$status "$http_user_agent" "$http_x_forwarded_for"
authorization="$http_authorization" cookie="$sent_http_set_cookie" ';
可以看出,这里定义了格式custom_log,这里记录了请求头authorization和响应头cookie。其他的信息,可以根据实际需要进行记录或者不记录。
2. 日志记录条件
location /ngtest {
set $loggable '0';
# 检查请求头
if ( $http_authorization ) {
set $loggable '1';
}
# 检查响应头
#if ( $sent_http_set_cookie ) {
# set $loggable '$loggable';
#}
#if ($loggable = 11) {
# access_log /var/log/nginx/testaccess.log mail;
#}
# 根据条件记录日志
access_log /var/log/nginx/testaccess.log custom_log if=$loggable;
proxy_pass http://127.0.0.1:8060;
#root /usr/share/nginx/html;
}
这里当请求中有authorization请求头时,设置标识$loggable为1,在日志记录的时候,根据$loggable的只决定是否记录访问日志。
3. 执行访问
使用postman访问配置的url。
可以看到指定的请求头和响应头。
注意:nginx的后端还需要启动一个服务,用于接收请求后返回信息中设置响应头信息。
4. 查看日志记录
111.206.85.18 - - [15/Oct/2024:17:36:25 +0800] "GET /ngtest HTTP/1.1" 200 "PostmanRuntime/7.28.4" "-" authorization="NTLM TlRMTVNTUA
ADAAAAGAAYAEAAAADCAMIAWAAAAAAAAAAAAAAAHAAcABoBAAAWABYANgEAAAAAAAAAAAAABYIIAJi+0X/kdkl/ONUQGF7iAm1ii5/nECrNEufop988HOhSTFsJVFvxdXYBAQ
AAAAAAAKAG+Vfn19oBYouf5xAqzRIAAAAAAgAGAE8AVABQAAEAHgBXAEkATgAtAEkAUgBEAFMAVgBKAE8AMwBVAFQAVAAEAA4AbwB0AHAALgBjAG8AbQADAC4AVwBJAE4ALQ
BJAFIARABTAFYASgBPADMAVQBUAFQALgBvAHQAcAAuAGMAbwBtAAUADgBvAHQAcAAuAGMAbwBtAAcACAD4/G0C59faA*******" cookie="mycookie=5ea7df386cd64620bfdef149cedb1a8f; Max-Age=3600; Expires=Tue, 22 Oct 2024 15:46:33 GMT; Path=/"
可以看到,日志中记录了请求头authorization,和响应的cookie。
还有请求的时间,以及请求的IP地址,请求地址,状态码,客户端agent等信息。
需要说明的是,这里记录的是access.log日志,而不是error.log日志。