Mam ten problem zarówno w Spring Boot 1.1.5, jak i 1.1.6 - ładuję zasób classpath za pomocą adnotacji @Value, która działa dobrze, gdy uruchamiam aplikację z poziomu STS (3.6.0, Windows). Jednak gdy uruchamiam pakiet mvn, a następnie próbuję uruchomić jar, pojawiają się wyjątki FileNotFound.
Zasób, message.txt, znajduje się w src / main / resources. Sprawdziłem jar i upewniłem się, że zawiera plik „message.txt” na najwyższym poziomie (na tym samym poziomie co application.properties).
Oto aplikacja:
@Configuration
@ComponentScan
@EnableAutoConfiguration
public class Application implements CommandLineRunner {
private static final Logger logger = Logger.getLogger(Application.class);
@Value("${message.file}")
private Resource messageResource;
public static void main(String[] args) {
SpringApplication.run(Application.class, args);
}
@Override
public void run(String... arg0) throws Exception {
// both of these work when running as Spring boot app from STS, but
// fail after mvn package, and then running as java -jar
testResource(new ClassPathResource("message.txt"));
testResource(this.messageResource);
}
private void testResource(Resource resource) {
try {
resource.getFile();
logger.debug("Found the resource " + resource.getFilename());
} catch (IOException ex) {
logger.error(ex.toString());
}
}
}
Wyjątek:
c:\Users\glyoder\Documents\workspace-sts-3.5.1.RELEASE\classpath-resource-proble
m\target>java -jar demo-0.0.1-SNAPSHOT.jar
. ____ _ __ _ _
/\\ / ___'_ __ _ _(_)_ __ __ _ \ \ \ \
( ( )\___ | '_ | '_| | '_ \/ _` | \ \ \ \
\\/ ___)| |_)| | | | | || (_| | ) ) ) )
' |____| .__|_| |_|_| |_\__, | / / / /
=========|_|==============|___/=/_/_/_/
:: Spring Boot :: (v1.1.5.RELEASE)
2014-09-16 08:46:34.635 INFO 5976 --- [ main] demo.Application
: Starting Application on 8W59XV1 with PID 5976 (C:\Users\glyo
der\Documents\workspace-sts-3.5.1.RELEASE\classpath-resource-problem\target\demo
-0.0.1-SNAPSHOT.jar started by glyoder in c:\Users\glyoder\Documents\workspace-s
ts-3.5.1.RELEASE\classpath-resource-problem\target)
2014-09-16 08:46:34.640 DEBUG 5976 --- [ main] demo.Application
: Running with Spring Boot v1.1.5.RELEASE, Spring v4.0.6.RELEA
SE
2014-09-16 08:46:34.681 INFO 5976 --- [ main] s.c.a.AnnotationConfigA
pplicationContext : Refreshing org.springframework.context.annotation.Annotation
ConfigApplicationContext@1c77b086: startup date [Tue Sep 16 08:46:34 EDT 2014];
root of context hierarchy
2014-09-16 08:46:35.196 INFO 5976 --- [ main] o.s.j.e.a.AnnotationMBe
anExporter : Registering beans for JMX exposure on startup
2014-09-16 08:46:35.210 ERROR 5976 --- [ main] demo.Application
: java.io.FileNotFoundException: class path resource [message.
txt] cannot be resolved to absolute file path because it does not reside in the
file system: jar:file:/C:/Users/glyoder/Documents/workspace-sts-3.5.1.RELEASE/cl
asspath-resource-problem/target/demo-0.0.1-SNAPSHOT.jar!/message.txt
2014-09-16 08:46:35.211 ERROR 5976 --- [ main] demo.Application
: java.io.FileNotFoundException: class path resource [message.
txt] cannot be resolved to absolute file path because it does not reside in the
file system: jar:file:/C:/Users/glyoder/Documents/workspace-sts-3.5.1.RELEASE/cl
asspath-resource-problem/target/demo-0.0.1-SNAPSHOT.jar!/message.txt
2014-09-16 08:46:35.215 INFO 5976 --- [ main] demo.Application
: Started Application in 0.965 seconds (JVM running for 1.435)
2014-09-16 08:46:35.217 INFO 5976 --- [ Thread-2] s.c.a.AnnotationConfigA
pplicationContext : Closing org.springframework.context.annotation.AnnotationCon
figApplicationContext@1c77b086: startup date [Tue Sep 16 08:46:34 EDT 2014]; roo
t of context hierarchy
2014-09-16 08:46:35.218 INFO 5976 --- [ Thread-2] o.s.j.e.a.AnnotationMBe
anExporter : Unregistering JMX-exposed beans on shutdown
źródło
classpath:filename
aby plik kluczy mógł zostać odczytany z pliku jar.Jeśli używasz frameworka Spring, czytanie
ClassPathResource
do aString
jest całkiem proste przy użyciu frameworka SpringFileCopyUtils
:źródło
Jeśli chcesz użyć pliku:
źródło
kiedy projekt rozruchu wiosennego działa jako jar i trzeba odczytać jakiś plik w ścieżce klas, implementuję go za pomocą poniższego kodu
źródło
Utworzyłem klasę ClassPathResourceReader w java 8 sposób, aby tworzyć łatwe do odczytania pliki ze ścieżki klas
Wykorzystanie:
źródło
Napotkałem również to ograniczenie i utworzyłem tę bibliotekę, aby rozwiązać problem: spring-boot-jar-resources Zasadniczo pozwala ona zarejestrować niestandardowy ResourceLoader za pomocą Spring Boot, który w razie potrzeby wyodrębnia zasoby ścieżki klas z JAR, w razie potrzeby.
źródło
źródło
Jersey musi być rozpakowany w słoikach.
źródło
źródło
Opierając się na odpowiedzi Andy'ego, użyłem poniższego, aby uzyskać strumienie wejściowe wszystkich YAML w katalogu i podkatalogach w zasobach (zauważ, że przekazana ścieżka nie zaczyna się od
/
):źródło
Utknąłem też w podobnej sytuacji, ale nie do końca podobnej, chciałem odczytać plik JSON z folderu zasobów. Src / main / resources Stąd napisałem kod podobny do tego poniżej.
Są tu wymienione różne sposoby odczytu pliku ze ścieżki klas rom w aplikacji Spring Boot.
@Value ("ścieżka klasy: test.json") prywatny zasób zasobu;
zasób zasobów prywatnych;
Teraz ten kod działa całkowicie dobrze po uruchomieniu go za pomocą mvn: spring-boot: run, ale gdy tylko buduję i pakuję aplikację za pomocą maven i uruchamiam ją jako prosty plik wykonywalny jar, pojawia się wyjątek. Przejdźmy dalej i znajdźmy teraz rozwiązanie.
Za pomocą InputStream znalazłem odpowiedź w moim przypadku: -
Wiosna działa na koncepcję Fat Jar, dlatego jest naprawdę trudna, ponieważ zachowuje się inaczej w Eclipse i gdy biegasz jako słoik.
źródło
W odniesieniu do pierwotnego komunikatu o błędzie
Poniższy kod może być pomocny w znalezieniu rozwiązania problemu ze ścieżką:
Dzięki temu można określić, gdzie aplikacja oczekuje brakującego pliku. Możesz to wykonać w głównej metodzie swojej aplikacji.
źródło