


How to load external configuration files after the SpringBoot project is made into a jar
1. External application.properties
Most of the configuration information is configured in application.properties, so can this file be external? Of course this is possible.
First define a property in application.preperties:
demo.name = hello.01
Use it in Controller:
@Value("${demo.name}") private String demoName; @RequestMapping("/test") public String test(){ return this.demoName; }
Type the project into a jar package and start it using java -jar:
java -jar springboot-out-properties-0.0.1-SNAPSHOT.jar
The value read at this time is: hello.01.
Copy the application.properties in the project and put it in the same path as the jar package. Modify the property value to:
demo.name = hello.02
Then use the above command to restart and see the effect. The value is hello.02. Surprising or not, Spring Boot is so awesome. The jar package can be read directly under the same path.
If we create a new config under the jar and put application.properties in it, can we identify it using the above command? The answer is yes,
SpringApplication will load properties from application.properties files in the following locations and add them to the Spring environment:
In the current directory /config subdirectory
classpath root directory
/config directory in classpath
current Directory
If a customized directory, such as conf, will not be recognized at this time, but you can use --spring.config.location to specify the path. The execution command is as follows:
java -jar springboot-out-properties-0.0.1-SNAPSHOT.jar--spring.config.location=conf/application.properties
Of course, you can also use the absolute path to specify:
java -jar springboot-out-properties-0.0.1-SNAPSHOT.jar--spring.config.location=/Users/linxiangxian/Downloads/conf/application.properties
2. @PropertySource External
In the project, some configurations will use customized properties files, such as defining demo.properties:
demo.nickname = hello.10 demo.weixin = springboot
Use @PropertySource to specify the configuration file:
/** * @PropertySource的例子 * <p> */ @Configuration @ConfigurationProperties(prefix = "demo") @PropertySource(value = {"classpath:demo.properties"}) public class DemoProperties { private String nickname; private String weixin; public String getNickname() { return nickname; } public void setNickname(String nickname) { this.nickname = nickname; } public String getWeixin() { return weixin; } public void setWeixin(String weixin) { this.weixin = weixin; } @Override public String toString() { return "DemoProperties{" + "nickname='" + nickname + '\'' + ", weixin='" + weixin + '\'' + '}'; } }
Then you can access this configuration file at this time, make it into a jar package, and execute the command:
java -jar springboot-out-properties-0.0.1-SNAPSHOT.jar
At this time The returned value is: hello.10
Put demo.properties in the same path as the jar package, modify the value of demo.name to hello.11, execute the above command, Barbie Q, the result is still hello .10, indicating that Spring Boot cannot find customized properties files from the outside.
So what can we do about this problem?
It’s very simple. @PropertySource supports multiple configurations and multiple paths, which can be configured like this:
@PropertySource(value = {"classpath:demo.properties","file:./demo.properties"},ignoreResourceNotFound = true)
When we configure multiple paths and the configuration files under the multiple paths exist, SpringBoot will load them all and will cover the same content. So when our configuration information only distinguishes external and internal paths and the contents are exactly the same, just write the file path at the end. When we start locally, because the file path does not exist, the classpath will be loaded; when the jar starts, the file path will overwrite the contents of the classpath path;
ignoreResourceNotFound = true must be added, otherwise it cannot be found An error will be reported. After adding, configuration files that cannot be found will be ignored.
At this point, just put the configuration file demo.properties under the same level as the jar package.
The above is the detailed content of How to load external configuration files after the SpringBoot project is made into a jar. For more information, please follow other related articles on the PHP Chinese website!

JavaachievesplatformindependencethroughtheJavaVirtualMachine(JVM),allowingcodetorunondifferentoperatingsystemswithoutmodification.TheJVMcompilesJavacodeintoplatform-independentbytecode,whichittheninterpretsandexecutesonthespecificOS,abstractingawayOS

Javaispowerfulduetoitsplatformindependence,object-orientednature,richstandardlibrary,performancecapabilities,andstrongsecurityfeatures.1)PlatformindependenceallowsapplicationstorunonanydevicesupportingJava.2)Object-orientedprogrammingpromotesmodulara

The top Java functions include: 1) object-oriented programming, supporting polymorphism, improving code flexibility and maintainability; 2) exception handling mechanism, improving code robustness through try-catch-finally blocks; 3) garbage collection, simplifying memory management; 4) generics, enhancing type safety; 5) ambda expressions and functional programming to make the code more concise and expressive; 6) rich standard libraries, providing optimized data structures and algorithms.

JavaisnotentirelyplatformindependentduetoJVMvariationsandnativecodeintegration,butitlargelyupholdsitsWORApromise.1)JavacompilestobytecoderunbytheJVM,allowingcross-platformexecution.2)However,eachplatformrequiresaspecificJVM,anddifferencesinJVMimpleme

TheJavaVirtualMachine(JVM)isanabstractcomputingmachinecrucialforJavaexecutionasitrunsJavabytecode,enablingthe"writeonce,runanywhere"capability.TheJVM'skeycomponentsinclude:1)ClassLoader,whichloads,links,andinitializesclasses;2)RuntimeDataAr

Javaremainsagoodlanguageduetoitscontinuousevolutionandrobustecosystem.1)Lambdaexpressionsenhancecodereadabilityandenablefunctionalprogramming.2)Streamsallowforefficientdataprocessing,particularlywithlargedatasets.3)ThemodularsystemintroducedinJava9im

Javaisgreatduetoitsplatformindependence,robustOOPsupport,extensivelibraries,andstrongcommunity.1)PlatformindependenceviaJVMallowscodetorunonvariousplatforms.2)OOPfeatureslikeencapsulation,inheritance,andpolymorphismenablemodularandscalablecode.3)Rich

The five major features of Java are polymorphism, Lambda expressions, StreamsAPI, generics and exception handling. 1. Polymorphism allows objects of different classes to be used as objects of common base classes. 2. Lambda expressions make the code more concise, especially suitable for handling collections and streams. 3.StreamsAPI efficiently processes large data sets and supports declarative operations. 4. Generics provide type safety and reusability, and type errors are caught during compilation. 5. Exception handling helps handle errors elegantly and write reliable software.


Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

Video Face Swap
Swap faces in any video effortlessly with our completely free AI face swap tool!

Hot Article

Hot Tools

SublimeText3 Mac version
God-level code editing software (SublimeText3)

Dreamweaver CS6
Visual web development tools

WebStorm Mac version
Useful JavaScript development tools

PhpStorm Mac version
The latest (2018.2.1) professional PHP integrated development tool

mPDF
mPDF is a PHP library that can generate PDF files from UTF-8 encoded HTML. The original author, Ian Back, wrote mPDF to output PDF files "on the fly" from his website and handle different languages. It is slower than original scripts like HTML2FPDF and produces larger files when using Unicode fonts, but supports CSS styles etc. and has a lot of enhancements. Supports almost all languages, including RTL (Arabic and Hebrew) and CJK (Chinese, Japanese and Korean). Supports nested block-level elements (such as P, DIV),
