1
2
3
4
5
6
7
8
9
10
11
12
13
14
15 package ch.qos.logback.classic.servlet;
16
17 import jakarta.servlet.ServletContextEvent;
18 import jakarta.servlet.ServletContextListener;
19
20 import org.slf4j.ILoggerFactory;
21 import org.slf4j.LoggerFactory;
22
23 import ch.qos.logback.classic.LoggerContext;
24 import ch.qos.logback.classic.util.StatusViaSLF4JLoggerFactory;
25 import ch.qos.logback.core.spi.ContextAwareBase;
26
27
28
29
30
31
32
33
34 public class LogbackServletContextListener implements ServletContextListener {
35
36 ContextAwareBase contextAwareBase = new ContextAwareBase();
37
38 @Override
39 public void contextInitialized(ServletContextEvent sce) {
40
41 }
42
43 @Override
44 public void contextDestroyed(ServletContextEvent sce) {
45
46 ILoggerFactory iLoggerFactory = LoggerFactory.getILoggerFactory();
47 if (iLoggerFactory instanceof LoggerContext) {
48 LoggerContext loggerContext = (LoggerContext) iLoggerFactory;
49 contextAwareBase.setContext(loggerContext);
50 StatusViaSLF4JLoggerFactory.addInfo("About to stop " + loggerContext.getClass().getCanonicalName() + " ["
51 + loggerContext.getName() + "]", this);
52 loggerContext.stop();
53 }
54 }
55
56 }