天天看点

springboot applications.yml配置HTML视图解析器_SpringBoot-自定义视图解析和自定义Starter...

自定义视图和自定义Starter做成统一配置,方便使用。
springboot applications.yml配置HTML视图解析器_SpringBoot-自定义视图解析和自定义Starter...

(一)自定义视图映射

在项目开发过程中,经常会涉及页面跳转问题,而且这个页面跳转没有任何业务逻辑过程,只是单纯的路由过程 ( 例如:点击一个按钮跳转到一个页面 ) 。
@RequestMapping("/testmvc") public String view(){ return "abc"; }
           
现在只需要这样统一写,此类必须在启动类所在包或者子包中

@Configuration

public class WebMvcConfig extends WebMvcConfigurerAdapter{

@Override

public void addViewControllers(ViewControllerRegistry registry) {

registry.addViewController("/testmvc").setViewName("/abc");

}

}

页面:abc.flt 或者 abc.html

访问http://localhost:8081/testmvc 即可访问到这个abc.flt文件]

hello
           

(二)自定义Starter

在我们学习SpringBoot时都已经了解到starter是SpringBoot的核心组成部分,SpringBoot为我们提供了尽可能完善的封装,提供了一系列的自动化配置的starter插件,我们在使用spring-boot-starter-web时只需要在pom.xml配置文件内添加依赖就可以了,我们之前传统方式则是需要添加很多相关SpringMVC配置文件。而spring-boot-starter-web为我们提供了几乎所有的默认配置,很好的降低了使用框架时的复杂度。因此在使用xx.starter时你就不用考虑该怎么配置,即便是有一些必要的配置在application.properties配置文件内对应配置就可以了,那好,为什么我在application.properties配置对应属性后xx.starter就可以获取到并作出处理呢?下面我们带着这个疑问来编写我们自定义的starter让我们深入了解SpringBoot。
  • 创建自己的starter项目
创建【普通maven项目】,修改pom.xml,增加自动配置依赖

org.springframework.boot

spring-boot-autoconfigure

1.5.10.RELEASE

我们这个starter并不做其他复杂逻辑的编写,所以这里的依赖只是添加了spring-boot-autoconfigure,实战开发时可以添加任意依赖到项目中。
  • 配置映射参数实体

starter是如何读取application.properties或者application.yml配置文件内需要的配置参数的呢?那么接下来我们就看看如何可以获取自定义的配置信息。

SpringBoot在处理这种事情上早就已经考虑到了,所以提供了一个注解@ConfigurationProperties,该注解可以完成将application.properties配置文件内的有规则的配置参数映射到实体内的field内,不过需要提供setter方法,自定义配置参数实体代码如下所示

@ConfigurationProperties(prefix = "hello")public class HelloProperties{ private String msg = "test"; public String getMsg() { return msg; } public void setMsg(String msg) { this.msg = msg; }}
           
在上面代码中,@ConfigurationProperties注解内我们使用到了属性preffix,该属性配置了读取参数的前缀,根据上面的实体属性对应配置文件内的配置则是hello.msg,当然我们提供了默认值,配置文件内不进行配置时则是使用默认值。
  • 编写自定义业务
自定义starter提供一个Service,并且提供一个名为sayHello的方法用于返回我们配置的msg内容。
public class HelloService{ private String msg; public String sayHello(){ return msg; } public void setMsg(String msg) { this.msg = msg; }}
           

Service内的代码比较简单,根据属性参数进行返回格式化后的字符串。

接下来我们开始编写自动配置,这一块是starter的核心部分,配置该部分后在启动项目时才会自动加载配置,当然其中有很多细节性质的配置。

  • 实现自动化配置
自动化配置其实只是提供实体bean的验证以及初始

@Configuration//开启配置

@EnableConfigurationProperties(HelloProperties.class)//开启使用映射实体对象

@ConditionalOnClass(HelloService.class)//存在HelloService时初始化该配置类

@ConditionalOnProperty//存在对应配置信息时初始化该配置类

(

prefix = "hello

继续阅读