nginx在access日志中记录请求头和响应头用作用户身份标识分析

在应用系统中,有时将请求的用户信息和身份认证信息放到请求头中,服务器认证通过后,通过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日志。

相关推荐
袁庭新3 小时前
M系列芯片Mac上通过Homebrew一键安装/卸载Nginx并上线项目全指南
运维·nginx·macos·袁庭新·袁庭新ai
Densen20143 小时前
发布blazor应用到Linux, 使用nginx作为WebSocket代理
linux·websocket·nginx
不是书本的小明4 小时前
Apache vs Nginx vs Tomcat 核心区别与优化
nginx·tomcat·apache
困惑阿三1 天前
客户消息及时反馈
nginx·node.js·飞书·企业微信
liurunlin8881 天前
httpslocalhostindex 配置的nginx,一刷新就报404了
运维·nginx
BullSmall1 天前
Nginx负载均衡会话保持配置指南
运维·nginx·负载均衡
你才是臭弟弟1 天前
Nginx部署前后端
运维·nginx
_下雨天.2 天前
Nginx性能调优与深度监控
运维·nginx
weiwx832 天前
Nginx location 和 proxy_pass 配置详解
服务器·网络·nginx