Details
- 
    Bug 
- 
    Resolution: Fixed
- 
    None
- 
    1.5.x
- 
    None
- 
    Operating System: All 
 Platform: All
- 
        major
- 
        P1
- 
        181
Description
org.apache.commons.logging.impl. SLF4JLogFactory
The class is open to a denial-of-service attack:
  public Log getInstance(String name) throws LogConfigurationException {
...
    synchronized (this) 
...
  }
@@@@
import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;
import org.apache.commons.logging.LogFactory;
public class Test {
  public static void main(String[] args) {
    ExecutorService pool = Executors.newCachedThreadPool();
    pool.execute(new Runnable() {
      public void run() {
        synchronized (LogFactory.getFactory()) 
      }
    });
    pool.execute(new Runnable() {
      public void run() 
    });
  }
}
@@@@
Use either:
private final Object lock = new Object();
synchronized(lock)
or:
synchronized(loggerMap)
@@
see also:
Bloch, Joshua. Effective Java (Second Edition). Sun Microsystems Press/Prentice-Hall, 2008. 280.