Spring Boot下

2018-02-27 11:56:08来源:oschina作者:anlve人点击

分享

《Spring Boot上》


上篇简要介绍了spring boot,以及简单的项目搭建


本篇主要说明一些注解和相关的配置介绍


==================================================


入口类和@SpringBootApplication注解

上文说过,我们新建一个Project系统都会帮我们创建一个名为artifactId+Application的入口类,这个类中有一个main方法,这个main方法就是一个标准的Java应用程序的入口方法。而这里的@SpringBootApplication则是一个组合注解,我们可以看它的源码:


@Target({ElementType.TYPE})
@Retention(RetentionPolicy.RUNTIME)
@Documented
@Inherited
@SpringBootConfiguration
@EnableAutoConfiguration
@ComponentScan(
excludeFilters = {@Filter(
type = FilterType.CUSTOM,
classes = {TypeExcludeFilter.class}
), @Filter(
type = FilterType.CUSTOM,
classes = {AutoConfigurationExcludeFilter.class}
)}
)
public @interface SpringBootApplication {
@AliasFor(
annotation = EnableAutoConfiguration.class,
attribute = "exclude"
)
Class<?>[] exclude() default {};
@AliasFor(
annotation = EnableAutoConfiguration.class,
attribute = "excludeName"
)
String[] excludeName() default {};
@AliasFor(
annotation = ComponentScan.class,
attribute = "basePackages"
)
String[] scanBasePackages() default {};
@AliasFor(
annotation = ComponentScan.class,
attribute = "basePackageClasses"
)
Class<?>[] scanBasePackageClasses() default {};
}

可以看到它组合了@SpringBootConfiguration、@EnableAutoConfiguration以及@ComponentScan,我们在开发的过程中如果不使用@SpringBootApplication,则可以组合使用这三个注解。这三个注解中,@SpringBootConfiguration就是@Configuration注解,是一个配置类,@EnableAutoConfiguration表示让Spring Boot根据类路径中的jar包依赖为当前项目进行自动配置,@ComponentScan的作用扫描实体类,唯一要注意的是如果我们使用了@SpringBootApplication注解的话,系统会去入口类的同级包以及下级包中去扫描实体类,因此我们建议入口类的位置在groupId+arctifactID组合的包名下。


关闭特定的自动配置

@ComponentScan注解有一个过滤器,如果只想要@SpringBootApplication去扫描特定的类而不是全部类,那么就可以关闭自动配置,如下:


@SpringBootApplication(exclude = DataSourceAutoConfiguration.class)
定制Banner 修改Banner

启动Spring Boot项目的时候,在控制台会默认输出一个启动图案,如下:

%20

这个图案是可以自己修改的,修改方式:


1.在src/main/resources下新建一个banner.txt文档

%20

2.通过http://patorjk.com/software/taag网站生成需要的字符,将字符拷贝到步骤1所创建的txt文档中,比如我这里为Hello%20iqux_anlve生成字符,如下:

%20

%20

控制台打印的效果

%20

%20关闭Banner%20

可以修改当然也可以关闭,关闭Banner需要修改一下main方法中的代码,如下

%20

%20
public%20static%20void%20main(String[]%20args)%20{
%20SpringApplicationBuilder%20builder%20=%20new%20SpringApplicationBuilder(TestSpringbootApplication.class);
%20//修改Banner的模式为OFF
%20builder.annerMode(Banner.Mode.OFF).run(args);
}%20

修改之后再次启动Project的时候就看不到Banner了。

%20Spring%20Boot的配置文件%20

Spring%20Boot使用一个全局的配置文件application.properties或者application.yml,配置文件放在src/main/resources目录下。properties是我们常见的一种配置文件,Spring%20Boot不仅支持properties这种类型的配置文件,也支持yaml语言的配置文件,我这里以properties类型的配置文件为例来看几个案例。

%20

1.修改Tomcat默认端口和默认访问路径

%20

Tomcat默认端口是8080,我将之改为8081,默认访问路径是http://localhost:8080,我将之改为http://localhost:8081/helloboot,我们来看看这两个需求要怎么样通过简单的配置来实现。

%20

很简单,在application.properties文件中添加如下代码:

%20

%20
server.context-path=/helloboot
server.port=8081%20

然后再启动Project,在浏览器中就得这样来访问了:

%20

%20常规属性配置%20

使用Spring%20Boot在Spring容器框架下注入properties文件里的值,只需要在application.properties中定义属性,然后在代码中直接使用@Value注入即可。

%20

如下:

%20
book.author=罗贯中%20
book.name=三国演义%20
book.pinyin=sanguoyanyi%20

这里设置了中文,因为中文不做特殊处理会乱码,处理方式为继续在application.properties中添加如下代码:

%20
server.tomcat.uri-encoding=UTF-8%20
spring.http.encoding.charset=UTF-8%20
spring.http.encoding.enabled=true%20
spring.http.encoding.force=true%20
spring.messages.encoding=UTF-8%20

然后%20在IntelliJ%20IDEA中依次点击File%20->%20Settings%20->%20Editor%20->%20File%20Encodings

%20

将Properties%20Files%20(*.properties)下的Default%20encoding%20for%20properties%20files设置为UTF-8,将Transparent%20native-to-ascii%20conversion前的勾选上。

%20

然后在变量中通过@Value直接注入就行了,如下:

%20
@Value(value%20=%20"${book.author}")%20
private%20String%20bookAuthor;%20
@Value("${book.name}")%20
private%20String%20bookName;%20
@Value("${book.pinyin}")%20
private%20String%20bookPinYin;%20

修改index方法,使之返回这些值:

%20
@RequestMapping(value%20=%20"/",produces%20=%20"text/plain;charset=UTF-8")
String%20index(){
%20return%20"Hello%20Spring%20Boot!%20The%20BookName%20is%20"+bookName+";and%20Book%20Author%20is%20"+bookAuthor+";and%20Book%20PinYin%20is%20"+bookPinYin;
}%20

然后在浏览器中访问,结果如下:

%20

%20
类型安全的配置%20

这种方式我们在实际项目中使用的时候工作量略大,因为每个项目要注入的变量的值太多了,这种时候我们可以使用基于类型安全的配置方式,就是将properties属性和一个Bean关联在一起,这样使用起来会更加方便。我么来看看这种方式怎么实现。

%20

1.在src/main/resources文件夹下创建文件book.properties

%20

文件内容如下:

%20
book.name=红楼梦%20
book.author=曹雪芹%20
book.price=28%20

2.创建Book%20Bean,并注入properties文件中的值

%20

代码如下:

%20
@Component
@ConfigurationProperties(prefix%20=%20"book",locations%20=%20"classpath:book.properties")
public%20class%20BookBean%20{
private%20String%20name;
private%20String%20author;
private%20String%20price;
public%20String%20getName()%20{
%20return%20name;
}
public%20void%20setName(String%20name)%20{
%20this.name%20=%20name;
}
public%20String%20getAuthor()%20{
%20return%20author;
}
public%20void%20setAuthor(String%20author)%20{
%20this.author%20=%20author;
}
public%20String%20getPrice()%20{
%20return%20price;
}
public%20void%20setPrice(String%20price)%20{
%20this.price%20=%20price;
}
}%20

prefix是指前缀,location指定要注入文件的位置。

%20

3.添加路径映射

%20

在Controller中添加如下代码注入Bean:

%20
@Autowired%20
private%20BookBean%20bookBean;%20

添加路径映射:

%20
@RequestMapping("/book")
public%20String%20book()%20{
%20return%20"Hello%20Spring%20Boot!%20The%20BookName%20is%20"+bookBean.getName()+";and%20Book%20Author%20is%20"+bookBean.getAuthor()+";and%20Book%20price%20is%20"+bookBean.getPrice();
}%20

运行效果如下:

%20


##注意:



##这里会有一些问题


日志配置

默认情况下Spring Boot使用Logback作为日志框架,可以手动配置日志级别以及日志输出位置,需要在application.properties中添加如下代码:


logging.file=/home/xxx/workspace/log.log
logging.level.org.springframework.web=debug

上面表示配置日志输出位置,下面配置日志级别。


Profile配置问题

在Spring Boot 中使用Profile更为简洁。全局Profile配置我们使用application-{profile}.properties来定义,然后在application.properties中通过spring.profiles.active来指定使用哪个Profile。


1.在src/main/resources文件夹下定义不同环境下的Profile配置文件,文件名分别为application-prod.properties和application-dev.properties,这两个前者表示生产环境下的配置,后者表示开发环境下的配置,如下:


最新文章

123

最新摄影

闪念基因

微信扫一扫

第七城市微信公众平台