使用Java实现HTTP请求头信息的日志记录与过滤

发布于:2024-06-22 ⋅ 阅读:(136) ⋅ 点赞:(0)

在Java Web开发中,日志记录是一个重要的环节,它可以帮助我们跟踪系统的运行状况,发现潜在的问题。对于HTTP请求来说,记录请求头信息尤其有用,因为它可以提供关于客户端环境、请求来源、以及可能的认证信息等。但是,直接记录所有头信息可能存在安全风险,比如密码等敏感信息被泄露。

下面,我们将展示一个使用Java实现的工具类LogUtils,它能够获取HTTP请求的所有头信息,并将其转换为字符串进行记录。同时,该工具类还包含了一个过滤机制,用于避免敏感信息(如密码)被记录。

 

 

import com.alibaba.fastjson.JSONObject;
import com.fasterxml.jackson.databind.ObjectMapper;
import lombok.extern.slf4j.Slf4j;
import org.aspectj.lang.JoinPoint;

import javax.servlet.http.HttpServletRequest;
import java.util.Enumeration;
import java.util.HashMap;
import java.util.Map;


@Slf4j
public class LogUtils {

    public static String getLogInfo(HttpServletRequest request, JoinPoint joinPoint, Object returnObject) {
        return map2String(getHeaderInfo(request));
    }

    /**
     * 用于获取全部头信息
     */
    private static Map<String, String> getHeaderInfo(HttpServletRequest request) {
        Map<String, String> map = new HashMap<>();
        Enumeration headerNames = request.getHeaderNames();
        while (headerNames.hasMoreElements()) {
            String key = (String) headerNames.nextElement();
            String value = request.getHeader(key);
            map.put(key, value);
        }
        return map;
    }

    /**
     * 把Map<String, String>转成String
     */
    public static String map2String(Map<String, String> parameterMap) {
        Map<String, Object> map = new HashMap<>();
        if (null != parameterMap) {
            for (Map.Entry<String, String> entry : parameterMap.entrySet()) {
                if (!entry.getKey().toLowerCase().contains("password")) {
                    map.put(entry.getKey(), entry.getValue());
                }
            }
        }
        return new JSONObject(map).toString();
    }


}


网站公告

今日签到

点亮在社区的每一天
去签到