当前位置: 首页 > article >正文

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="-"

可以看到,日志中记录了请求头authorization,和响应的cookie。

还有请求的时间,以及请求的IP地址,请求地址,状态码,客户端agent等信息。

需要说明的是,这里记录的是access.log日志,而不是error.log日志。


http://www.kler.cn/news/357087.html

相关文章:

  • 微信小程序上传组件封装uploadHelper2.0使用整理
  • NodeJS 使用百度翻译API
  • scala继承
  • Java中常见的自带数据结构类
  • (小白教程)MPV.NET 播放器安装和添加Bilibili弹幕
  • 速盾:cdn加速访问网站过程
  • 物理安全概述
  • 矩阵系统哪家好~矩阵短视频运营~怎么矩阵OEM
  • 【MR开发】在Pico设备上接入MRTK3(三)——在Unity中运行MRTK示例
  • C++算法练习-day9——24.两两交换链表中的节点
  • 快速上手C语言【下】(非常详细!!!)
  • 理工科考研想考计算机,湖南大学、重大、哈工大威海、山东大学,该如何选择?
  • 基于微信小程序的购物系统【附源码、文档】
  • FBB-Frontiers in Bioengineering and Biotechnology
  • AI学习指南深度学习篇-自编码器的变种
  • 【从零开发Mybatis】构建SQL映射语句对应的MappedStatement对象
  • 创始人抖音百科:品牌与形象的双重加速器!
  • vue综合指南(二)
  • 每日OJ题_牛客_最长回文子序列_区间DP_C++_Java
  • 腾讯云宝塔面板前后端项目发版