一尘不染

tomcat:如何在tomcat日志中记录用户名?

tomcat

我尝试取消注释server.xml中的阀线。未注释的行是

<Valve className="org.apache.catalina.valves.AccessLogValve" directory="logs"
       prefix="localhost_access_log." suffix=".txt" pattern="common" resolveHosts="false"/>

它仅记录正在访问的URL。它没有记录谁发出了请求。

在tomcat中执行此操作的正确方法是什么?


阅读 362

收藏
2020-06-16

共1个答案

一尘不染

您选择了“通用”模式;您需要指定一种自定义模式,如下所示。“%u”变量代表“已认证的用户”。下面的链接列出了您可以使用的所有其他变量。

http://tomcat.apache.org/tomcat-7.0-doc/config/valve.html#Access_Log_Valve

    <Valve className="org.apache.catalina.valves.AccessLogValve"
             directory="logs"  prefix="access." suffix=".log"
             pattern="%h %l %u %t '%r' %s %b"
             resolveHosts="false"/>
2020-06-16