1、SpringBoot2.x使用Dev-tool熱部署 簡介:介紹什麼是熱部署,使用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 不被熱部署的文件 一、/META-INF/maven, /META-INF/resources, /resources, /static, /public, or /templates 二、指定文件不進行熱部署 spring.devtools.restart.exclude=static/**,public/** 三、手工觸發重啓 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是不會進行熱部署的 2、SpringBoot2.x配置文件講解 簡介:SpringBoot2.x常見的配置文件 xml、yml、properties的區別和使用 xml、properties、json、yaml 一、常見的配置文件 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 二、默認示例文件僅做爲指導。 不要將整個內容複製並粘貼到您的應用程序中,只挑選您須要的屬性。 三、參考:https://docs.spring.io/spring-boot/docs/2.1.0.BUILD-SNAPSHOT/reference/htmlsingle/#common-application-properties 若是須要修改,直接複製對應的配置文件,加到application.properties裏面 3、SpringBoot註解配置文件自動映射到屬性和實體類實戰 簡介:講解使用@value註解配置文件自動映射到屬性和實體類 一、配置文件加載 方式一 一、Controller上面配置 @PropertySource({"classpath:resource.properties"}) 二、增長屬性 @Value("${test.name}") private String name; 方式二:實體類配置文件 步驟: 一、添加 @Component 註解; 二、使用 @PropertySource 註解指定配置文件位置; 三、使用 @ConfigurationProperties 註解,設置相關屬性; 四、必須 經過注入IOC對象Resource 進來 , 才能在類中使用獲取的配置文件值。 @Autowired private ServerSettings serverSettings; 例子: @Configuration @ConfigurationProperties(prefix="test") @PropertySource(value="classpath:resource.properties") public class ServerConstant { 常見問題: 一、配置文件注入失敗,Could not resolve placeholder 解決:根據springboot啓動流程,會有自動掃描包沒有掃描到相關注解, 默認Spring框架實現會從聲明@ComponentScan所在的類的package進行掃描,來自動注入, 所以啓動類最好放在根路徑下面,或者指定掃描包範圍 spring-boot掃描啓動類對應的目錄和子目錄 二、注入bean的方式,屬性名稱和配置文件裏面的key一一對應,就用加@Value 這個註解 若是不同,就要加@value("${XXX}") 4、SpringBoot個性化啓動banner設置和debug日誌 簡介:自定義應用啓動的趣味性日誌圖標和查看調試日誌 一、啓動獲取更多信息 java -jar xxx.jar --debug 二、修改啓動的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 5、SpringBoot2.x配置全局異常實戰 講解:服務端異常講解和SpringBoot配置全局異常實戰 一、默認異常測試 int i = 1/0,不友好 二、異常註解介紹 @ControllerAdvice 若是是返回json數據 則用 RestControllerAdvice,就能夠不加 @ResponseBody //捕獲全局異常,處理全部不可知的異常 @ExceptionHandler(value=Exception.class) 6、SpringBoot2.x配置全局異常返回自定義頁面 簡介:使用SpringBoot自定義異常和錯誤頁面跳轉實戰 一、返回自定義異常界面,須要引入thymeleaf依賴 <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-thymeleaf</artifactId> </dependency> 二、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 7、SpringBoot啓動方式講解和部署war項目到tomcat9 簡介:SpringBoot常見啓動方式講解和部署war項目Tomcat 一、ide啓動 二、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 三、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 四、啓動容器介紹和第三方測試數據講解 使用Jmter測試工具測試性能,QPS,TPS,RT https://examples.javacodegeeks.com/enterprise-java/spring/tomcat-vs-jetty-vs-undertow-comparison-of-spring-boot-embedded-servlet-containers/ 8、深刻SpringBoot過濾器和Servlet3.0配置過濾器實戰 簡介:講解SpringBoot裏面Filter講解和使用Servlet3.0配置自定義Filter實戰 filter簡單理解:人--->檢票員(filter)---> 景點 一、SpringBoot啓動默認加載的Filter characterEncodingFilter hiddenHttpMethodFilter httpPutFormContentFilter requestContextFilter 二、Filter優先級 Ordered.HIGHEST_PRECEDENCE Ordered.LOWEST_PRECEDENCE 低位值意味着更高的優先級 Higher values are interpreted as lower priority 自定義Filter,避免和默認的Filter優先級同樣,否則會衝突 註冊Filter的bean FilterRegistrationBean 同模塊裏面有相關默認Filter web->servlet->filter 三、自定義Filter 1)使用Servlet3.0的註解進行配置 2)啓動類裏面增長 @ServletComponentScan,進行掃描 3)新建一個Filter類,implements Filter,並實現對應的接口 4) @WebFilter 標記一個類爲filter,被spring進行掃描 urlPatterns:攔截規則,支持正則 6)控制chain.doFilter的方法的調用,來實現是否經過放行 不放行,web應用resp.sendRedirect("/index.html"); 場景:權限控制、用戶登陸(非前端後端分離場景)等 一、 官網地址:https://docs.spring.io/spring-boot/docs/2.1.0.BUILD-SNAPSHOT/reference/htmlsingle/#boot-features-embedded-container-servlets-filters-listeners 9、Servlet3.0的註解原生Servlet實戰 講解:使用 Servlet3.0的註解自定義原生Servlet和Listener 一、自定義原生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); } } 10、Servlet3.0的註解原生Listener監聽器實戰 簡介:監聽器介紹和Servlet3.0的註解自定義原生Listener監聽器實戰 一、自定義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========"); } 11、SpringBoot2.X攔截器實戰及新舊配置對比 簡介: 講解攔截器使用,Spingboot2.x新版本配置攔截攔截器和舊版本SpringBoot配置攔截器區別講解 一、@Configuration 繼承WebMvcConfigurationAdapter(SpringBoot2.X以前舊版本) SpringBoot2.X 新版本配置攔截器 implements WebMvcConfigurer 二、自定義攔截器 HandlerInterceptor preHandle:調用Controller某個方法以前 postHandle:Controller以後調用,視圖渲染以前,若是控制器Controller出現了異常,則不會執行此方法 afterCompletion:無論有沒有異常,這個afterCompletion都會被調用,用於資源清理 三、按照註冊順序進行攔截,先註冊,先被攔截 攔截器不生效常見問題: 1)是否有加@Configuration 2)攔截路徑是否有問題 ** 和 * 3)攔截器最後路徑必定要 「/**」, 若是是目錄的話則是 /*/ Filter 是基於函數回調 doFilter(),而Interceptor則是基於AOP思想 Filter在只在Servlet先後起做用,而Interceptor夠深刻到方法先後、異常拋出先後等 依賴於Servlet容器即web應用中,而Interceptor不依賴於Servlet容器因此能夠運行在多種環境。 在接口調用的生命週期裏,Interceptor能夠被屢次調用,而Filter只能在容器初始化時調用一次。 Filter和Interceptor的執行順序 過濾前->攔截前->action執行->攔截後->過濾後
可結合以前的博文 2018最新SpringBoot2.0教程(零基礎入門)觀看理解html
更多學習資料可參考:https://xdclass.net/html/course_catalogue.html?video_id=4前端