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日志。

相关推荐
Narutolxy6 小时前
使用 Nginx 实现动态图片加水印:技术探索与实践指南20250122
运维·nginx
�时过境迁,物是人非9 小时前
ECS中实现Nginx四层和七层负载均衡以及ALB/NLB实现负载均衡
运维·nginx·负载均衡
东软吴彦祖10 小时前
包安装利用 LNMP 实现 phpMyAdmin 的负载均衡并利用Redis实现会话保持nginx
linux·redis·mysql·nginx·缓存·负载均衡
牙牙70511 小时前
ansible一键安装nginx二进制版本
服务器·nginx·ansible
苹果醋31 天前
golang 编程规范 - Effective Go 中文
java·运维·spring boot·mysql·nginx
KwokRoot1 天前
Nginx正向代理配置
运维·nginx
myshare20221 天前
深入探索 Nginx 的高级用法:解锁 Web 服务器的强大潜能
nginx
Lime-30901 天前
Nginx+Tomcat实现动静分离
java·服务器·nginx
计算机毕设定制辅导-无忧学长1 天前
Nginx 反向代理与负载均衡配置实践
运维·nginx·负载均衡
m0_748240022 天前
CentOS部署FastDFS+Nginx并实现远程访问本地服务器中文件
服务器·nginx·centos