I\'m trying to migrate a Playframework application from 2.4 to 2.5.3 and I have problems to get values from application.conf
file:
Before t
you should try to remove private
.
use:
@Inject Configuration configuration;
instead of:
@Inject private Configuration configuration;
Try with constructor injection instead:
import javax.inject.Inject;
import play.Configuration;
import play.Logger;
public class Zipper {
private Configuration configuration;
@Inject
public Zipper(Configuration config) {
this.configuration = config;
}
public void unZip(String zipFilePath) {
Logger.debug("Display : zipFilePath"+zipFilePath);
Logger.debug("before call parameter from application.conf");
Logger.debug("configuration.getString = "+configuration.getString("Unzipedfile.path"));
Logger.debug("aftercall parameter from application.conf");
}
}
I'm not sure that Guice is capable of inject private
fields. Anyway, constructor injection is the recommended injection type.
I put here the answer, in order to help anyone with the same issue
My error came from the way i used to instantiate my Zipper java class from my calling class.
Thx to Igmar Palsenberg, he provided me the answer : https://groups.google.com/forum/?utm_medium=email&utm_source=footer#!topic/play-framework/uLFqTM9_Iy4
I used Zipper zipTest = new Zipper(); to instanciate my Zipper class and i have to use Zipper zipTest = injector.instanceOf(Zipper.class);
Try to annotate your class with Singleton so that play can detect your bean to inject your resources.
I think that you can initialize the configuration like this:
private Configuration configuration = Play.current().injector().instanceOf(Configuration .class);
So, your Zipper will be:
import javax.inject.Inject;
import play.Configuration;
import play.Logger;
public class Zipper {
private Configuration configuration = Play.current().injector().instanceOf(Configuration .class);
public void unZip(String zipFilePath) {
Logger.debug("Display : zipFilePath"+zipFilePath);
Logger.debug("before call parameter from application.conf");
Logger.debug("configuration.getString = "+configuration.getString("Unzipedfile.path"));
Logger.debug("aftercall parameter from application.conf");
}
}