メインクラスにロガーを次のように作成しました。
public static Logger logger = Logger.getLogger( MainClass.class.getName());
public static と宣言しました。
これは 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
今、別のクラスでこのロガー オブジェクトにアクセスしたいと考えています。ロガーを直接与えようとすると、パブリック静的にしましたがエラーが発生します。
以下は、ロガーオブジェクトにアクセスしようとしているクラスです:
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;
}
}