文章目录
1. springboot项目运行在外部容器
- 打成war形式
<packaging>war</packaging>
- 添加tomcat的依赖
<!--部署到外部tomcat中需要的依赖-->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-tomcat</artifactId>
<version>1.5.1.RELEASE</version>
<scope>provide</scope>
</dependency>
- 启动类继承SpringBootServletInitializer
@SpringBootApplication
public class CloudStartApplication extends SpringBootServletInitializer {
public static void main(String[] args) {
SpringApplication.run(CloudStartApplication.class, args);
}
@Override
protected SpringApplicationBuilder configure(SpringApplicationBuilder application) {
return application.sources(CloudStartApplication.class);
}
}
启动类应该在最外面的包,即和它同级下的所有类及子包下的类才可以把springBoot来管理,要注意这点。
2. @ConfigurationProperties(key=“person”)
通过注解@ConfigurationProperties(prefix=“配置文件中的key的前缀”)可以将配置文件中的自定义属性自动与实体进行映
射,注意要和@Bean或@Configure结合使用,不然会报错。
application.properties配置如下:
#用于演示@ConfigurationProperties加载配置文件中的自定义值
person.name=jun
person.age=12
person.birthday=2019-08-05
#person.height=3
另外还需要个person的Dto,此处不再展示。
演示代码如下:
@ConfigurationProperties(prefix="person")
@RestController
@Api(tags = "自定义属性properties获取测试")
@RequestMapping("/person")
public class PropertiesController {
private String name;
private Integer age;
@Value("${person.birthday}")
private String birthday;
/**
* 此处演示@Value引用的值不存在时指定默认值
*/
@Value("${person.height:2}")
private Integer height;
@GetMapping("/get")
@ApiOperation(value = "测试自定义属性properties获取",notes = "返回person对象")
public BaseResponse<PersonDto> getPerson(){
BaseResponse<PersonDto> response = new BaseResponse<>();
PersonDto personDto = new PersonDto(name, age, birthday,height);
response.setData(personDto);
return response;
}
/**
* 注意:使用@ConfigurationProperties必须为属性提供set方法,而Value就不必。
* @param name name
*/
public void setName(String name){
this.name = name;
}
public void setAge(Integer age){
this.age = age;
}
}
3. bootstramp.yml文件是什么
其实yml和properties文件是一样的,主要说明application和bootstrap的加载顺序。
Bootstrap.yml(bootstrap.properties)在application.yml(application.properties)之前加载,就像application.yml一样,但是用于应用程序上下文的引导阶段。它通常用于“使用Spring Cloud Config Server时,应在bootstrap.yml中指定spring.application.name和spring.cloud.config.server.git.uri”以及一些加密/解密信息。技术上,bootstrap.yml由父Spring ApplicationContext加载。父ApplicationContext被加载到使用application.yml的之前。
例如,当使用Spring Cloud时,通常从服务器加载“real”配置数据。为了获取URL(和其他连接配置,如密码等),您需要一个较早的“bootstrap”配置。因此,您将配置服务器属性放在bootstrap.yml中,该属性用于加载实际配置数据(通常覆盖application.yml [如果存在]中的内容)。
当然,在一些情况上不用那么区分这两个文件,你只需要使用application文件即可,把全部选项都写在这里,效果基本是一致的,在不考虑上面的加载顺序覆盖的问题上。
4. 日期格式转换
向前端传输字段为LocalDate或者LocalDateTime类型时,我们需要指定格式,否则会发生解析错误。方式有两种:
1.在对象属性上增加 @JsonFormat(timezone = “GMT+8”,pattern = “yyyy-MM-dd”)或者@JsonFormat(shape = JsonFormat.Shape.NUMBER)转成时间戳,由前端再转换。
2.利用springmvc的messageConvert,这个对所有的controller都生效,是推荐的方式。
5. @Autowired注解、@Resource注解的区别
@Resource的作用相当于@Autowired,只不过@Autowired按byType自动注入,而@Resource默认按 byName自动注入罢了。@Resource有两个属性是比较重要的,分是name和type,Spring将@Resource注解的name属性解析为bean的名字,而type属性则解析为bean的类型。
@Resource装配顺序
1. 如果同时指定了name和type,则从Spring上下文中找到唯一匹配的bean进行装配,找不到则抛出异常
2. 如果指定了name,则从上下文中查找名称(id)匹配的bean进行装配,找不到则抛出异常
3. 如果指定了type,则从上下文中找到类型匹配的唯一bean进行装配,找不到或者找到多个,都会抛出异常
4. 如果既没有指定name,又没有指定type,则自动按照byName方式进行装配;当找不到与名称匹配的bean时才按照类型进行装配
@Autowired 与@Resource的区别:
- @Autowired与@Resource都可以用来装配bean. 都可以写在字段上,或写在setter方法上。
- @Autowired默认按类型装配(这个注解是属于spring的),默认情况下必须要求依赖对象必须存在,如果要允许null值,可以设置它的required属性为false,如:@Autowired(required=false) ,如果我们想使用名称装配可以结合@Qualifier注解进行使用,如下:
@Autowired()
@Qualifier("baseDao")
private BaseDao baseDao;
- @Resource(这个注解属于J2EE的),默认安装名称进行装配,名称可以通过name属性进行指定,如果没有指定name属性,当注解写在字段上时,默认取字段名进行安装名称查找,如果注解写在setter方法上默认取属性名进行装配。当找不到与名称匹配的bean时才按照类型进行装配。但是需要注意的是,如果name属性一旦指定,就只会按照名称进行装配。
@Resource(name="baseDao")
private BaseDao baseDao;
推荐使用:@Resource注解在字段上,并且这个注解是属于J2EE的,减少了与spring的耦合,这样代码看起就比较优雅。