1、DevTools 热部署
1.1 在pom.xml引入相关配置
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-devtools</artifactId>
<optional>true</optional>
</dependency>
<!--将应用打成可直接运行的jar(该jar就是用于生产环境中的jar)-->
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
<configuration>
<fork>true</fork>
</configuration>
</plugin>
1.2 在IDEA settings配置中勾线标红的
项目修改之后:Ctrl+F9;
2、配置提示
自定义的类与配置文件绑定一般没有提示:(application.properties和application.yml)同时生效
2.1、pom.xml里面加入如下配置:
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-configuration-processor</artifactId>
<optional>true</optional>
</dependency>
<build>
<plugins>
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
<configuration>
<excludes>
<exclude>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-configuration-processor</artifactId>
</exclude>
</excludes>
</configuration>
</plugin>
</plugins>
</build>
2.2、实体类
import lombok.Data;
import lombok.ToString;
import org.springframework.boot.context.properties.ConfigurationProperties;
@Data
@ToString
@ConfigurationProperties(prefix = "com.test")
public class Green {
private String a;
private String b;
}
2.3、重新编译
在target目录下的META_INF 下生成spring-configuration-metadata.json文件
3、拦截器
3.1、pom.xml里面加入如下配置:
<dependency>
<groupId>com.fasterxml.jackson.dataformat</groupId>
<artifactId>jackson-dataformat-xml</artifactId>
</dependency>
<dependency>
<groupId>com.fasterxml.jackson.core</groupId>
<artifactId>jackson-databind</artifactId>
</dependency>
3.2、配置拦截器的信息
@Slf4j
public class FastOneInterceptor implements HandlerInterceptor {
@Override
public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception {
log.info("这是拦截的preHandle方法。。。");
return false;
}
@Override
public void postHandle(HttpServletRequest request, HttpServletResponse response, Object handler, @Nullable ModelAndView modelAndView) throws Exception {
log.info("这是目标方法执行后的postHandle方法。。。");
}
@Override
public void afterCompletion(HttpServletRequest request, HttpServletResponse response, Object handler, @Nullable Exception ex) throws Exception {
log.info("这是页面渲染后执行后的afterCompletion方法。。。{}",ex);
}
}
@Configuration
public class BootConfig implements WebMvcConfigurer {
@Override
public void addInterceptors(InterceptorRegistry registry) {
registry.addInterceptor(new FastOneInterceptor())
.addPathPatterns("/**")//被拦截的所有的请求
.excludePathPatterns("/one/**");//过滤的请求
}
}
3.3、拦截器的原理
1、根据当前请求,找到HandlerExecutionChain【可以处理请求的handler以及handler的所有 拦截器】
2、先来顺序执行 所有拦截器的 preHandle方法
● 如果当前拦截器prehandler返回为true。则执行下一个拦截器的preHandle
● 如果当前拦截器返回为false。直接 倒序执行所有已经执行了的拦截器的 afterCompletion;
3、如果任何一个拦截器返回false。直接跳出不执行目标方法
4、所有拦截器都返回True。执行目标方法
5、倒序执行所有拦截器的postHandle方法。
6、前面的步骤有任何异常都会直接倒序触发 afterCompletion
7、页面成功渲染完成以后,也会倒序触发 afterCompletion
4、Web原生组件注入(Servlet、Filter、Listener)
4.1、Servlet的使用
//在配置类里面定义servlet的扫描路径
@Configuration
@ServletComponentScan(basePackages="com.example.springboottest.config")
public class BootConfig implements WebMvcConfigurer {
}
package com.example.springboottest.config;
import javax.servlet.ServletException;
import javax.servlet.annotation.WebServlet;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import java.io.IOException;
//定义servlet继承HttpServlet
@WebServlet("/doservlet")//访问路径
public class FastOneServlet extends HttpServlet {
@Override
public void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
System.out.println("调用servlet请求......");
}
@Override
public void doPost(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
this.doGet(req,resp);
}
}
4.2、Filter的使用
首先servlet的扫描路径
@Slf4j
@WebFilter(urlPatterns = {"/one/*"}) //配置要拦截的请求 /*是拦截所有
public class FastOneFilter extends HttpFilter {
@Override
public void doFilter(HttpServletRequest request, HttpServletResponse response, FilterChain chain) throws IOException, ServletException {
log.info("过滤器的方法调用。。。。。。。。。。。");
chain.doFilter(request, response);
}
}
4.3、Listener的使用
@WebListener //监听器
public class FastOneListener implements ServletContextListener {
@Override
public void contextDestroyed(ServletContextEvent sce) {
System.out.println("===========================销毁的方法==================");
}
@Override
public void contextInitialized(ServletContextEvent sce) {
System.out.println("===========================初始化的方法==================");
//打印当前的服务器
System.out.println(sce.getServletContext().getServerInfo());
}
}
5、application-profile功能
为了方便多环境适配,springboot简化了profile功能。
● 指定环境配置文件 application-{env}.yaml
● 激活指定环境
1、 配置文件激活
2、命令行激活:java -jar xxx.jar --spring.profiles.active=prod
修改配置文件的任意值,命令行优先
spring:
profiles:
active: prod