07《Spring Boot 入门教程》Spring Boot 详解配置文件

1. 前言

Spring Boot 可以在零配置的情况下使用,但是不代表 Spring Boot 完全不需要配置文件。

举一个简单的例子, Spring Boot 开发的 Web 项目默认的启动端口是 8080 。如果我们想更换启动端口,通过配置文件去修改是比较好的。如果放到代码中,修改一个端口都要重新编译下程序,岂不烦哉?

配置文件不是必须的,但是如果想实现一些个性化的功能,还是需要用到配置文件的。本篇就讲下 Spring Boot 中使用配置文件的常用场景。

2. 构建演示 Web 项目

为了便于演示,我们先构建一个 Web 项目。

2.1 使用 Spring Initializr 构建一个 Spring Boot 应用

Spring Boot 版本选择 2.2.5 , Group 为 com.imooc , Artifact 为 spring-boot-profile ,生成项目后导入 Eclipse 开发环境。

2.2 修改 pom.xml

引入 Web 项目依赖,同时开启热部署便于修改测试。

实例:

        <!-- 热部署 -->
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-devtools</artifactId>
        </dependency>
        <!-- web -->
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
        </dependency>

2.3 编写控制器用于测试

实例:

@RestController // 标注为控制器,且返回值序列化为json
public class HelloController {
    @GetMapping("/hello") // 响应get请求,匹配的请求路径为/hello
    public Map hello() {
        Map<String, String> map = new HashMap<String, String>();
        map.put("test", "content for test");
        return map;
    }
}

2.4 启动项目

访问 http://127.0.0.1:8080/hello ,效果如下:

5ea6e81e0889eb8c06990157.jpg

浏览器显示返回数据

3. 修改项目启动配置

我们运行启动类,启动 spring-boot-profile 应用,控制台会发现如下提示:

Tomcat started on port(s): 8080 (http) with context path ''

可以看出, Spring Boot 应用默认启动端口是 8080 ,默认项目路径是空。

我们可以通过修改 resources/application.properties 来自定义项目启动配置:

实例:

# 启动端口
server.port=8000
# 项目路径
server.servlet.context-path=/spring-boot-profile

再次启动应用,控制台提示变为:

Tomcat started on port(s): 8000 (http) with context path '/spring-boot-profile'

此时项目对应的访问路径为: http://127.0.0.1:8000/spring-boot-profile , 使用浏览器访问效果如下:

5ea6e82d089b71a206990241.jpg

浏览器显示返回数据

4. 配置文件格式

Spring Boot 支持两种格式的配置文件,即 .properties 文件和 .yml 配置文件。

上面的配置使用 .yml 则为:

实例:

server: 
 port: 8000
 servlet: 
   context-path: /spring-boot-profile

.properties 配置使用顿号分割语义,而 .yml 配置使用缩进分割语义。这两种配置文件没有本质区别,只是格式不同。

5. 自定义配置项

我们还可以在配置文件中使用自定义配置,例如我们开发了一个微信公众号后台应用,需要在程序中配置公众号的 appid 和 secret 。

配置文件如下:

实例:

# 公众号appid
wxmp.appid=111
# 公众号secret
wxmp.secret=222

我们定义一个组件,通过 @Value 注解注入配置项的值。

实例:

/**
 * 微信公众号参数
 */
@Component//注册为组件
public class WxMpParam {
    @Value("${wxmp.appid}")//注入wxmp.appid配置项
    private String appid;
    @Value("${wxmp.secret}")//注入wxmp.secret配置项
    private String secret;
  //省略get set方法
}

通过控制器测试配置项是否注入成功。

实例:

@RestController 
public class HelloController {
    @Autowired
    private WxMpParam wxMpParam;
    @GetMapping("/hello") 
    public Map hello() {
        Map<String, String> map = new HashMap<String, String>();
        map.put("appid",wxMpParam.getAppid());
        map.put("secret",wxMpParam.getSecret());
        return map;
    }
}

此时我们访问 http://127.0.0.1:8000/spring-boot-profile/hello ,浏览器显示如下,说明我们的配置注入成功。

5ea6e83e08f573ec07000153.jpg

浏览器显示返回数据

6. 配置项自动注入对象

如果参数很多,一一指定对象属性和配置项的关联非常麻烦。可以通过设定对象与配置项的对应关系,来实现配置项的自动注入。

实例:

@Component // 注册为组件
@EnableConfigurationProperties // 启用配置自动注入功能
@ConfigurationProperties(prefix = "wxmp") // 指定类对应的配置项前缀
public class WxMpParam {
    private String appid;// 对应到wxmp.appid
    private String secret; // 对应到wxmp.secret
  //省略 get set
}

在上面的代码中,通过 prefix = "wxmp" 指定了关联配置的前缀,属性 appid 即关联到前缀 + 属性名为 wxmp.appid 的配置项。同理,属性 secret 关联到 wxmp.secret 配置项。

7. 在配置文件中使用随机数

配置文件中使用随机数也是比较常见的场景,尤其启动多个客户端时,希望指定一个启动端口的范围,例如 10 - 20 ,可配置如下:

实例:

# 配置端口为1-20间的随机数
server.port=${random.int[10,20]}

这样我可以连续启动四个客户端,启动端口分别是 12 、 13 、 17 、 19 ,可见是随机的,而且在我指定的范围内波动。

8. 自定义配置文件

有时候参数太多,都放到一个配置文件中太乱了,我们会希望将配置分到不同文件中,然后每个文件保存不同配置。

例如上面微信公众号配置,我们单独建立一个 wxmp.properties 文件,内容如下:

实例:

# wxmp.properties配置文件

# 公众号的appid
wxmp.appid=111
# 公众号的secret
wxmp.secret=222

WxMpParam 代码如下:

实例:

/**
* 微信公众号参数
*/
@Component // 注册为组件
@PropertySource(value = "classpath:wxmp.properties", encoding = "utf-8") // 指定配置文件及编码
public class WxMpParam {
   @Value("${wxmp.appid}")
   private String appid;
   @Value("${wxmp.secret}")
   private String secret;
}

9. 配置项引用

Spring Boot 配置项是可以引用其他配置项的值的,这个稍微提一下,例如:

实例:

# wxmp.properties

# 公众号的appid
wxmp.appid=111
# 公众号的secret,值为111222
wxmp.secret=${wxmp.appid}222 

10. 小结

对一个 Spring Boot 应用而言。

  • 如果配置项比较少,直接全部写在 application.properties
  • 如果配置项很多,可以划分为若干配置文件。
  • 如果很多自定义配置拥有相同的前缀,可以指定前缀,让配置项自动注入对象中。
  • Spring Boot 提供了多变的配置文件使用机制,我们根据具体场景灵活使用即可。
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 216,193评论 6 498
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,306评论 3 392
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 162,130评论 0 353
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,110评论 1 292
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,118评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,085评论 1 295
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,007评论 3 417
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,844评论 0 273
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,283评论 1 310
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,508评论 2 332
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,667评论 1 348
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,395评论 5 343
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,985评论 3 325
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,630评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,797评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,653评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,553评论 2 352

推荐阅读更多精彩内容