org.apache.rocketmq.shaded.ch.qos.logback.classic.selector.servlet.LoggerContextFilter Maven / Gradle / Ivy
/**
* Logback: the reliable, generic, fast and flexible logging framework.
* Copyright (C) 1999-2015, QOS.ch. All rights reserved.
*
* This program and the accompanying materials are dual-licensed under
* either the terms of the Eclipse Public License v1.0 as published by
* the Eclipse Foundation
*
* or (per the licensee's choosing)
*
* under the terms of the GNU Lesser General Public License version 2.1
* as published by the Free Software Foundation.
*/
package org.apache.rocketmq.shaded.ch.qos.logback.classic.selector.servlet;
import java.io.IOException;
import javax.servlet.Filter;
import javax.servlet.FilterChain;
import javax.servlet.FilterConfig;
import javax.servlet.ServletException;
import javax.servlet.ServletRequest;
import javax.servlet.ServletResponse;
import org.apache.rocketmq.shaded.org.slf4j.LoggerFactory;
import org.apache.rocketmq.shaded.ch.qos.logback.classic.LoggerContext;
import org.apache.rocketmq.shaded.ch.qos.logback.classic.selector.ContextJNDISelector;
import org.apache.rocketmq.shaded.ch.qos.logback.classic.selector.ContextSelector;
import org.apache.rocketmq.shaded.ch.qos.logback.classic.util.ContextSelectorStaticBinder;
/**
* A servlet filter that puts the environment dependent LoggerContext in a
* ThreadLocal variable, removing it after the request is processed.
*
* To use it, add the following lines to a web.xml file
*
*
* LoggerContextFilter
*
* org.apache.rocketmq.shaded.ch.qos.logback.classic.selector.servlet.LoggerContextFilter
*
*
*
* LoggerContextFilter
* /*
*
*
* @author Sébastien Pennec
*/
public class LoggerContextFilter implements Filter {
public void destroy() {
// do nothing
}
public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain) throws IOException, ServletException {
LoggerContext lc = (LoggerContext) LoggerFactory.getILoggerFactory();
ContextSelector selector = ContextSelectorStaticBinder.getSingleton().getContextSelector();
ContextJNDISelector sel = null;
if (selector instanceof ContextJNDISelector) {
sel = (ContextJNDISelector) selector;
sel.setLocalContext(lc);
}
try {
chain.doFilter(request, response);
} finally {
if (sel != null) {
sel.removeLocalContext();
}
}
}
public void init(FilterConfig arg0) throws ServletException {
// do nothing
}
}