1. 端口号
在主要独立应用程序中,主 HTTP 端口默认为 8080;我们可以轻松地将 Boot 配置为使用不同的端口:
server.port=8083
对于基于 YAML 的配置:
server:
port: 8083
我们还可以通过编程方式自定义服务器端口:
@Component
public class CustomizationBean implements
WebServerFactoryCustomizer<ConfigurableServletWebServerFactory> {
@Override
public void customize(ConfigurableServletWebServerFactory container) {
container.setPort(8083);
}
}
2. 上下文路径
默认情况下,上下文路径为“/”。如果这不理想并且您需要将其更改为类似 /app_name 的内容,以下是通过属性执行此操作的快速简单方法:
server.servlet.contextPath=/springbootapp
对于基于 YAML 的配置:
server:
servlet:
contextPath:/springbootapp
最后 – 更改也可以以编程方式完成:
@Component
public class CustomizationBean
implements WebServerFactoryCustomizer<ConfigurableServletWebServerFactory> {
@Override
public void customize(ConfigurableServletWebServerFactorycontainer) {
container.setContextPath("/springbootapp");
}
}
3. 白标错误页面
如果你没有在配置中指定任何自定义实现,Spring Boot 会自动注册一个 BasicErrorController bean。
但是,当然可以配置此默认控制器:
public class MyCustomErrorController implements ErrorController {
private static final String PATH = "/error";
@GetMapping(value=PATH)
public String error() {
return "Error haven";
}
}
4.自定义错误消息
默认情况下,Boot 提供 /error 映射,以合理的方式处理错误。如果要配置更具体的错误页面,可以很好地支持统一的Java DSL来自定义错误处理:
@Component
public class CustomizationBean
implements WebServerFactoryCustomizer<ConfigurableServletWebServerFactory> {
@Override
public void customize(ConfigurableServletWebServerFactorycontainer) {
container.addErrorPages(new ErrorPage(HttpStatus.BAD_REQUEST, "/400"));
container.addErrorPages(new ErrorPage("/errorHaven"));
}
}
在这里,我们专门处理了错误请求以匹配 /400 路径,并处理所有其他路径以匹配公共路径。还有一个非常简单的 /errorHaven 实现:
@GetMapping("/errorHaven")
String errorHeaven() {
return "You have reached the haven of errors!!!";
}
输出:
You have reached the haven of errors!!!
5. 以编程方式关闭启动应用程序
您可以在 SpringApplication 的帮助下以编程方式关闭 Boot 应用程序。这有一个静态 exit()方法,它接受两个参数:ApplicationContext 和一个 ExitCodeGenerator:
@Autowired
public void shutDown(ExecutorServiceExitCodeGenerator exitCodeGenerator) {
SpringApplication.exit(applicationContext, exitCodeGenerator);
}
正是通过这个实用程序方法,我们可以关闭应用程序。
6. 配置日志记录级别
您可以在引导应用程序中轻松调整日志记录级别;从版本 1.2.0 开始,您可以在主属性文件中配置日志级别:
logging.level.org.springframework.web: DEBUG
logging.level.org.hibernate: ERROR
就像标准的Spring应用程序一样,您可以通过在类路径中添加自定义XML或属性文件并在pom中定义库来激活不同的日志记录系统,如Logback,log4j,log4j2等。
7. 注册一个新的 Servlet
如果您在嵌入式服务器的帮助下部署应用程序,则可以通过在常规配置中将它们公开为bean来在boot应用程序中注册新的Servlet:
@Bean
public HelloWorldServlet helloWorld() {
return new HelloWorldServlet();
}
或者,您可以使用 ServletRegistrationBean:
@Bean
public SpringHelloServletRegistrationBean servletRegistrationBean() {
SpringHelloServletRegistrationBean bean = new SpringHelloServletRegistrationBean(
new SpringHelloWorldServlet(), "/springHelloWorld/*");
bean.setLoadOnStartup(1);
bean.addInitParameter("message", "SpringHelloWorldServlet special message");
return bean;
}
8. 在Boot Application中配置 Jetty or Undertow
Spring Boot 启动器通常使用 Tomcat 作为默认的嵌入式服务器。如果需要更改 - 您可以排除Tomcat依赖项并改为包含Jetty或Undertow:
配置 Jetty
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
<exclusions>
<exclusion>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-tomcat</artifactId>
</exclusion>
</exclusions>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-jetty</artifactId>
</dependency>
@Bean
public JettyEmbeddedServletContainerFactory jettyEmbeddedServletContainerFactory() {
JettyEmbeddedServletContainerFactory jettyContainer =
new JettyEmbeddedServletContainerFactory();
jettyContainer.setPort(9000);
jettyContainer.setContextPath("/springbootapp");
return jettyContainer;
}
配置Undertow
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
<exclusions>
<exclusion>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-tomcat</artifactId>
</exclusion>
</exclusions>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-undertow</artifactId>
</dependency>
@Bean
public UndertowEmbeddedServletContainerFactory embeddedServletContainerFactory() {
UndertowEmbeddedServletContainerFactory factory =
new UndertowEmbeddedServletContainerFactory();
factory.addBuilderCustomizers(new UndertowBuilderCustomizer() {
@Override
public void customize(io.undertow.Undertow.Builder builder) {
builder.addHttpListener(8080, "0.0.0.0");
}
});
return factory;
}