零基礎快速入門SpringBoot2.0 教程(二)
簡介:介紹什麽是熱部署,使用springboot結合dev-tool工具,快速加載啟動應用
官方地址:https://docs.spring.io/spring-boot/docs/2.1.0.BUILD-SNAPSHOT/reference/htmlsingle/#using-boot-devtools 核心依賴包: <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-devtools</artifactId> <optional>true</optional> </dependency> 添加依賴後,在ide裏面重啟應用,後續修改後馬上可以生效 classloader 不被熱部署的文件 1、/META-INF/maven, /META-INF/resources, /resources, /static, /public, or /templates 2、指定文件不進行熱部署 spring.devtools.restart.exclude=static/**,public/** 3、手工觸發重啟 spring.devtools.restart.trigger-file=trigger.txt 改代碼不重啟,通過一個文本去控制 https://docs.spring.io/spring-boot/docs/2.1.0.BUILD-SNAPSHOT/reference/htmlsingle/#using-boot-devtools-restart-exclude 註意點:生產環境不要開啟這個功能,如果用java -jar啟動,springBoot是不會進行熱部署的
二、SpringBoot2.x配置文件講解
簡介:SpringBoot2.x常見的配置文件 xml、yml、properties的區別和使用
xml、properties、json、yaml 1、常見的配置文件 xx.yml, xx.properties, 1)YAML(Yet Another Markup Language) 寫 YAML 要比寫 XML 快得多(無需關註標簽或引號) 使用空格 Space 縮進表示分層,不同層次之間的縮進可以使用不同的空格數目 註意:key後面的冒號,後面一定要跟一個空格,樹狀結構 application.properties示例 server.port=8090 server.session-timeout=30 server.tomcat.max-threads=0 server.tomcat.uri-encoding=UTF-8 application.yml示例 server: port: 8090 session-timeout: 30 tomcat.max-threads: 0 tomcat.uri-encoding: UTF-8 2、默認示例文件僅作為指導。 不要將整個內容復制並粘貼到您的應用程序中,只挑選您需要的屬性。 3、參考:https://docs.spring.io/spring-boot/docs/2.1.0.BUILD-SNAPSHOT/reference/htmlsingle/#common-application-properties 如果需要修改,直接復制對應的配置文件,加到application.properties裏面
三、SpringBoot註解配置文件自動映射到屬性和實體類實戰
簡介:講解使用@value註解配置文件自動映射到屬性和實體類
1、配置文件加載 方式一 1、Controller上面配置 @PropertySource({"classpath:resource.properties"}) 2、增加屬性 @Value("${test.name}") private String name; 方式二:實體類配置文件 步驟: 1、添加 @Component 註解; 2、使用 @PropertySource 註解指定配置文件位置; 3、使用 @ConfigurationProperties 註解,設置相關屬性; 4、必須 通過註入IOC對象Resource 進來 , 才能在類中使用獲取的配置文件值。 @Autowired private ServerSettings serverSettings; 例子: @Configuration @ConfigurationProperties(prefix="test") @PropertySource(value="classpath:resource.properties") public class ServerConstant { 常見問題: 1、配置文件註入失敗,Could not resolve placeholder 解決:根據springboot啟動流程,會有自動掃描包沒有掃描到相關註解, 默認Spring框架實現會從聲明@ComponentScan所在的類的package進行掃描,來自動註入, 因此啟動類最好放在根路徑下面,或者指定掃描包範圍 spring-boot掃描啟動類對應的目錄和子目錄 2、註入bean的方式,屬性名稱和配置文件裏面的key一一對應,就用加@Value 這個註解 如果不一樣,就要加@value("${XXX}")
四、SpringBoot個性化啟動banner設置和debug日誌
簡介:自定義應用啟動的趣味性日誌圖標和查看調試日誌
1、啟動獲取更多信息 java -jar xxx.jar --debug
2、修改啟動的banner信息
1)在類路徑下增加一個banner.txt,裏面是啟動要輸出的信息
2)在applicatoin.properties增加banner文件的路徑地址
spring.banner.location=banner.txt
3)官網地址 https://docs.spring.io/spring-boot/docs/2.1.0.BUILD-SNAPSHOT/reference/htmlsingle/#boot-features-banners
五、SpringBoot2.x配置全局異常實戰
講解:服務端異常講解和SpringBoot配置全局異常實戰
1、默認異常測試 int i = 1/0,不友好
2、異常註解介紹
@ControllerAdvice 如果是返回json數據 則用 RestControllerAdvice,就可以不加 @ResponseBody
//捕獲全局異常,處理所有不可知的異常
@ExceptionHandler(value=Exception.class)
六、SpringBoot2.x配置全局異常返回自定義頁面
簡介:使用SpringBoot自定義異常和錯誤頁面跳轉實戰
1、返回自定義異常界面,需要引入thymeleaf依賴
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-thymeleaf</artifactId>
</dependency>
2、resource目錄下新建templates,並新建error.html
ModelAndView modelAndView = new ModelAndView();
modelAndView.setViewName("error.html");
modelAndView.addObject("msg", e.getMessage());
return modelAndView;
https://docs.spring.io/spring-boot/docs/2.1.0.BUILD-SNAPSHOT/reference/htmlsingle/#boot-features-error-handling
七、SpringBoot啟動方式講解和部署war項目到tomcat9
簡介:SpringBoot常見啟動方式講解和部署war項目Tomcat
1、ide啟動
2、jar包方式啟動
maven插件:
<build>
<plugins>
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
</plugin>
</plugins>
</build>
如果沒有加,則執行jar包 ,報錯如下
java -jar spring-boot-demo-0.0.1-SNAPSHOT.jar
no main manifest attribute, in spring-boot-demo-0.0.1-SNAPSHOT.jar
如果有安裝maven 用 mvn spring-boot:run
項目結構
example.jar
|
+-META-INF
| +-MANIFEST.MF
+-org
| +-springframework
| +-boot
| +-loader
| +-<spring boot loader classes>
+-BOOT-INF
+-classes
| +-mycompany
| +-project
| +-YourClasses.class
+-lib
+-dependency1.jar
+-dependency2.jar
目錄結構講解
https://docs.spring.io/spring-boot/docs/2.1.0.BUILD-SNAPSHOT/reference/htmlsingle/#executable-jar-jar-file-structure
3、war包方式啟動
1)在pom.xml中將打包形式 jar 修改為war <packaging>war</packaging>
構建項目名稱 <finalName>xdclass_springboot</finalName>
2)tocmat下載 https://tomcat.apache.org/download-90.cgi
3)修改啟動類
public class XdclassApplication extends SpringBootServletInitializer {
@Override
protected SpringApplicationBuilder configure(SpringApplicationBuilder application) {
return application.sources(XdclassApplication.class);
}
public static void main(String[] args) throws Exception {
SpringApplication.run(XdclassApplication.class, args);
}
}
4)打包項目,啟動tomcat
4、啟動容器介紹和第三方測試數據講解
使用Jmter測試工具測試性能,QPS,TPS,RT
https://examples.javacodegeeks.com/enterprise-java/spring/tomcat-vs-jetty-vs-undertow-comparison-of-spring-boot-embedded-servlet-containers/
八、深入SpringBoot過濾器和Servlet3.0配置過濾器實戰
簡介:講解SpringBoot裏面Filter講解和使用Servlet3.0配置自定義Filter實戰
filter簡單理解:人--->檢票員(filter)---> 景點
1、SpringBoot啟動默認加載的Filter
characterEncodingFilter
hiddenHttpMethodFilter
httpPutFormContentFilter
requestContextFilter
2、Filter優先級
Ordered.HIGHEST_PRECEDENCE
Ordered.LOWEST_PRECEDENCE
低位值意味著更高的優先級 Higher values are interpreted as lower priority
自定義Filter,避免和默認的Filter優先級一樣,不然會沖突
註冊Filter的bean FilterRegistrationBean
同模塊裏面有相關默認Filter
web->servlet->filter
3、自定義Filter
1)使用Servlet3.0的註解進行配置
2)啟動類裏面增加 @ServletComponentScan,進行掃描
3)新建一個Filter類,implements Filter,並實現對應的接口
4) @WebFilter 標記一個類為filter,被spring進行掃描
urlPatterns:攔截規則,支持正則
6)控制chain.doFilter的方法的調用,來實現是否通過放行
不放行,web應用resp.sendRedirect("/index.html");
場景:權限控制、用戶登錄(非前端後端分離場景)等
1、 官網地址:https://docs.spring.io/spring-boot/docs/2.1.0.BUILD-SNAPSHOT/reference/htmlsingle/#boot-features-embedded-container-servlets-filters-listeners
九、Servlet3.0的註解原生Servlet實戰
講解:使用 Servlet3.0的註解自定義原生Servlet和Listener
1、自定義原生Servlet
@WebServlet(name = "userServlet",urlPatterns = "/test/customs")
public class UserServlet extends HttpServlet{
@Override
public void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
resp.getWriter().print("custom sevlet");
resp.getWriter().flush();
resp.getWriter().close();
}
@Override
protected void doPost(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
this.doGet(req, resp);
}
}
十、Servlet3.0的註解原生Listener監聽器實戰
簡介:監聽器介紹和Servlet3.0的註解自定義原生Listener監聽器實戰
1、自定義Listener(常用的監聽器 servletContextListener、httpSessionListener、servletRequestListener)
@WebListener
public class RequestListener implements ServletRequestListener {
@Override
public void requestDestroyed(ServletRequestEvent sre) {
// TODO Auto-generated method stub
System.out.println("======requestDestroyed========");
}
@Override
public void requestInitialized(ServletRequestEvent sre) {
System.out.println("======requestInitialized========");
}
十一、SpringBoot2.X攔截器實戰及新舊配置對比
簡介: 講解攔截器使用,Spingboot2.x新版本配置攔截攔截器和舊版本SpringBoot配置攔截器區別講解
1、@Configuration
繼承WebMvcConfigurationAdapter(SpringBoot2.X之前舊版本)
SpringBoot2.X 新版本配置攔截器 implements WebMvcConfigurer
2、自定義攔截器 HandlerInterceptor
preHandle:調用Controller某個方法之前
postHandle:Controller之後調用,視圖渲染之前,如果控制器Controller出現了異常,則不會執行此方法
afterCompletion:不管有沒有異常,這個afterCompletion都會被調用,用於資源清理
3、按照註冊順序進行攔截,先註冊,先被攔截
攔截器不生效常見問題:
1)是否有加@Configuration
2)攔截路徑是否有問題 ** 和 *
3)攔截器最後路徑一定要 “/**”, 如果是目錄的話則是 /*/
Filter
是基於函數回調 doFilter(),而Interceptor則是基於AOP思想
Filter在只在Servlet前後起作用,而Interceptor夠深入到方法前後、異常拋出前後等
依賴於Servlet容器即web應用中,而Interceptor不依賴於Servlet容器所以可以運行在多種環境。
在接口調用的生命周期裏,Interceptor可以被多次調用,而Filter只能在容器初始化時調用一次。
Filter和Interceptor的執行順序
過濾前->攔截前->action執行->攔截後->過濾後
教程會繼續更新。。。。
更多學習資料可參考:https://xdclass.net/html/course_catalogue.html?video_id=4
http://edu.51cto.com/course/13539.html
零基礎快速入門SpringBoot2.0 教程(二)