访问不同类的记录器

时间:2013-06-18 06:11:11

标签: java logging

我在我的主类中创建了一个记录器:

public static Logger logger = Logger.getLogger( MainClass.class.getName());

我宣布它是静态的。

这是log4j.properties:

根记录器选项

log4j.rootLogger=INFO, file

将日志消息直接发送到日志文件

log4j.appender.file=org.apache.log4j.RollingFileAppender
log4j.appender.file.File=D:\\loging.log
log4j.appender.file.MaxFileSize=10MB
log4j.appender.file.MaxBackupIndex=1
log4j.appender.file.layout=org.apache.log4j.PatternLayout
log4j.appender.file.layout.ConversionPattern=%d{yyyy-MM-dd HH:mm:ss} %-5p %c{1}:%L - %m%n

现在我想在不同的类中访问此logger对象。 当我尝试直接给出记录器时,虽然我将其设为公共静态,但却给出了错误。

以下是我尝试访问logger对象的类:

public class Db_Connector 
{
     MainClass.logger <------error
     //create ResultSet Class Object
     public ResultSet GetDataFromDB(){

        ResultSet resultset = null;
         try {  

                DriverManager.registerDriver(new oracle.jdbc.driver.OracleDriver());   
                System.out.println("Connecting to the database...");   
                Connection connection = DriverManager.getConnection(
                        "jdbc:oracle:thin:@host:1521:Db", "User","pass01");
                Statement statement = connection.createStatement();   
                resultset = statement.executeQuery("select * from employee"); 

            } 
         catch (Exception e) {   
                System.out.println("The exception raised is:" + e);   
                            } 

         return resultset;
        }   
}

2 个答案:

答案 0 :(得分:1)

确保包装Logger的Class也是公开的

答案 1 :(得分:0)

您应该在DB_Connector类中创建public static变量并为其分配MainClass.logger。