零基礎快速入門SpringBoot2.0教程 (二)


一、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
 	
 	不被熱部署的文件
 		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執行->攔截后->過濾后

可結合之前的博文 2018最新SpringBoot2.0教程(零基礎入門)觀看理解

更多學習資料可參考:https://xdclass.net/html/course_catalogue.html?video_id=4

https://ke.qq.com/course/299498 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM