Невозможно загрузить .properties в приложении для Tomcat - PullRequest
2 голосов
/ 05 декабря 2010


Мне нужно написать веб-приложение, которое подключается к базе данных и читает свойства подключения из файла .properties.
Я использую Maven и хочу написать тестовый модуль для своего приложения.
Чтобы проверить классы, которые работают с базой данных, я поместил свой файл .properties в src / main / resources и в test / main / resources и написал следующий код для чтения свойств:

package util;

import java.io.IOException;
import java.io.InputStream;
import java.util.Properties;
import org.apache.log4j.Logger;


/**
 *
 * @author proger
 */
public class ProgrammSettings {

    private static Logger logger = Logger.getRootLogger();
    private static String propertiesPath = "program.settings.properties";

    private static Properties props;

    public static String getProperty(String key) {
        if (props == null)
            loadProperties();

       return props.getProperty(key);

    }

    public static void setResourcesFilePath(String path) {
        propertiesPath = path;
    }

    private static void loadProperties() {
        InputStream propOut = null;
        try {
            //URL url =  ClassLoader.getSystemResource(propertiesPath);
            propOut = ClassLoader.getSystemClassLoader().getResourceAsStream(propertiesPath); //new FileInputStream(url.getFile());
            props = new Properties();
            props.load(propOut);
        } catch (Exception ex) {
            //Logger.getLogger(ProgrammSettings.class.getName()).log(Level.SEVERE, null, ex);
            String errorMessage = "Error during properties file reading. Path to file: '" +
                           propertiesPath + "'";
            logger.error(errorMessage, ex);
            throw new RuntimeException(errorMessage, ex);
        } finally {
            try {
                if (propOut != null)
                    propOut.close();
            } catch (IOException ex) {
                logger.error("Error during closing stream from properties file", ex);
            }
        }
    }
}

Я хотел, чтобы один и тот же код работал как для тестов, так и для классов приложений, поэтому я прочитал файл свойств из classPath. Все мои тесты пройдены, и мой файл .properties упакован в войну Maven. Но когда я запускаю свое приложение из Netbeans, я получаю:

java.lang.NullPointerException
    java.util.Properties$LineReader.readLine(Properties.java:435)
    java.util.Properties.load0(Properties.java:354)
    java.util.Properties.load(Properties.java:342)
    util.ProgrammSettings.loadProperties(ProgrammSettings.java:49)
    util.ProgrammSettings.getProperty(ProgrammSettings.java:33)
    dataacess.AbstractDataMapper.loadDriver(AbstractDataMapper.java:58)
    dataacess.AbstractDataMapper.<init>(AbstractDataMapper.java:41)
    dataacess.UserMapper.<init>(UserMapper.java:25)
    servlets.UserRegistration.processRequest(UserRegistration.java:86)
    servlets.UserRegistration.doPost(UserRegistration.java:132)
    javax.servlet.http.HttpServlet.service(HttpServlet.java:637)
    javax.servlet.http.HttpServlet.service(HttpServlet.java:717)
    org.netbeans.modules.web.monitor.server.MonitorFilter.doFilter(MonitorFilter.java:393)

Как я могу это исправить? Заранее спасибо

1 Ответ

3 голосов
/ 05 декабря 2010

Поместите program.settings.properties в webapps/appname/WEB-INF/classes

И вы можете использовать более простую строку ProgrammSettings.class.getResourceAsStream(..) (т.е. не системный загрузчик классов, а текущий загрузчик классов)

...