Spring Boot项目属性配置
接着上面的入门教程,我们来学习下Spring Boot的项目属性配置。
1、配置项目内置属性
属性配置主要是在application.properties文件里配置的(编写时有自动提示)这里我们将server的端口变为8888,路径加上HelloWorld:
在DeomApplication.java的页面时点击运行按钮,打开浏览器输入:http://localhost:8888/HelloWorld/hello
此时,控制台的输出信息也可以看到端口变成8888了:
之前的url已无效:
更改后的URL有效:
2、配置自定义属性
同样也是在application.properties文件编写,内容如下:
接着在HelloWorldController.java中使用@Value注解将自定义属性注入,这样可以直接使用自定义属性了:
运行项目,输入:http://localhost:8888/HelloWorld/hello,浏览器将显示如下结果:
3、ConfigurationProperties 配置
新建一个com.example.properties包,再新建一个MysqlProperties.java类,经测试运行会出错,无法找到该Bean,错误如下:
百度后找到了原因:
SpringBoot项目的Bean装配默认规则是根据Application类所在的包位置从上往下扫描!
io.github.gefangshuai.app
,则只会扫描io.github.gefangshuai.app
包及其所有子包,如果service或dao所在包不在io.github.gefangshuai.app
及其子包下,则不会被扫描!于是将MysqlProperties.java类移动了com.example.demo包下,也就是Application类所在的包,就没报bean找不到的错误了。
MysqlProperties.java用到了2个重要的注解:
1、@Component:把普通pojo实例化到spring容器中,相当于配置文件中的<bean id="" class=""/>
2、@ConfigurationProperties(prefix = "mysql"):将配置类注入到spring容器中,这样可以使用配置类,这里使用了前缀。
编写完成,IDEA会提示改属性有问题,原因是spring-boot-configuration-processor.jar包没有引入,在pom.xml加入如下依赖:
1 <dependency> 2 <groupId>org.springframework.boot</groupId> 3 <artifactId>spring-boot-configuration-processor</artifactId> 4 <optional>true</optional> 5 </dependency>
MysqlProperties.java代码如下(使用Alt+Insert快捷键生成Getter和Setter方法):
1 package com.example.demo; 2 3 import org.springframework.boot.context.properties.ConfigurationProperties; 4 import org.springframework.stereotype.Component; 5 6 /** 7 * Mysql属性配置 8 */ 9 @Component 10 @ConfigurationProperties(prefix = "mysql") 11 public class MysqlProperties { 12 13 private String jdbcName; 14 15 private String dbUrl; 16 17 private String userName; 18 19 private String password; 20 21 public String getJdbcName() { 22 return jdbcName; 23 } 24 25 public void setJdbcName(String jdbcName) { 26 this.jdbcName = jdbcName; 27 } 28 29 public String getDbUrl() { 30 return dbUrl; 31 } 32 33 public void setDbUrl(String dbUrl) { 34 this.dbUrl = dbUrl; 35 } 36 37 public String getUserName() { 38 return userName; 39 } 40 41 public void setUserName(String userName) { 42 this.userName = userName; 43 } 44 45 public String getPassword() { 46 return password; 47 } 48 49 public void setPassword(String password) { 50 this.password = password; 51 } 52 }
application.properties添加的属性如下:
1 mysql.jdbcName=com.mysql.jdbc.Driver 2 mysql.dbUrl=jdbc:mysql://localhost:3306/db_boot 3 mysql.userName=root 4 mysql.password=root
HelloWordController.java的最终代码为:
1 package com.example.demo; 2 3 import org.springframework.beans.factory.annotation.Value; 4 import org.springframework.stereotype.Controller; 5 import org.springframework.web.bind.annotation.RequestMapping; 6 import org.springframework.web.bind.annotation.ResponseBody; 7 8 import javax.annotation.Resource; 9 10 11 /** 12 * Created on 2017-9-3. 13 */ 14 @Controller 15 public class HelloWorldController { 16 17 @Value("${hellWorld}") 18 private String helloWorld; 19 20 @Resource 21 private MysqlProperties mysqlPropertie; 22 23 @RequestMapping("/hello") 24 @ResponseBody 25 public String say(){ 26 return helloWorld; 27 } 28 29 @RequestMapping("/showJdbc") 30 @ResponseBody 31 public String showJdbc(){ 32 return "mysql.jdbcName" + mysqlPropertie.getJdbcName() +"<br/>" 33 + "mysql.dbUrl" + mysqlPropertie.getDbUrl() +"<br/>" 34 + "mysql.userName" + mysqlPropertie.getUserName() +"<br/>" 35 + "mysql.password" + mysqlPropertie.getPassword() +"<br/>"; 36 37 } 38 39 40 }
运行项目,浏览器输入:http://localhost:8888/showJdbc,正确结果如下:
本文来自博客园,作者:Javanumberone,转载请注明原文链接:https://www.cnblogs.com/stm32stm32/p/7469663.html
posted on 2017-09-03 22:30 Javanumberone 阅读(553) 评论(0) 编辑 收藏 举报