田源
2025-01-16 cfd8d4c470cc6db6f6689ebf01eae07e47a46990
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
package com.vci.client.common;
 
import java.io.File;
import java.io.FileInputStream;
import java.net.URL;
 
 
import org.apache.logging.log4j.LogManager;
import org.apache.logging.log4j.Logger;
import org.apache.logging.log4j.core.config.ConfigurationSource;
import org.apache.logging.log4j.core.config.Configurator;
 
 
/**
 * <p>Title: </p>
 * <p>Description: use log4j to note some meaningful info.
 * the info has four kinds: INFO, DEBUG, WARN and ERROR.
 * it display log infos in console and save them into a
 * log file. Programeers can lookup useful info from them.
 * And programeers can set the level in 
 * properties/ClientWithLog4j.properties to decide which info
 * they want to save.</p>
 */
public class ClientLog4j {
    private static String log4j_properties_dev = "properties/ClientLog4j2.xml";
    private static String log4j_properties = "/" + log4j_properties_dev;
    private static URL log4j_properties_url = null;
    
    
    public static Logger logger = null;//LogManager.getLogger("ServerLog");
    
    static {
        try {
            File file =  new File(log4j_properties_dev);
            String loadFrom = "";
            
            if(file.exists()){
                loadFrom = file.getAbsolutePath();
            } else {
                log4j_properties_url = ClientLog4j.class.getResource(log4j_properties);
                loadFrom = log4j_properties_url.toString();
            }
            
            ConfigurationSource source = new ConfigurationSource(new FileInputStream(loadFrom));
            Configurator.initialize(null, source);
            
            logger = LogManager.getLogger("ClientLog");
            
            logger.debug("log4j init completed. use properties file is " + loadFrom);
        } catch (Exception e) {
            e.printStackTrace();
        }
    }
    
}