技術(shù)介紹
為甘泉等地區(qū)用戶提供了全套網(wǎng)頁設計制作服務,及甘泉網(wǎng)站建設行業(yè)解決方案。主營業(yè)務為做網(wǎng)站、成都網(wǎng)站設計、甘泉網(wǎng)站設計,以傳統(tǒng)方式定制建設網(wǎng)站,并提供域名空間備案等一條龍服務,秉承以專業(yè)、用心的態(tài)度為用戶提供真誠的服務。我們深信只要達到每一位用戶的要求,就會得到認可,從而選擇與我們長期合作。這樣,我們也可以走得更遠!
devtools:是boot的一個熱部署工具,當我們修改了classpath下的文件(包括類文件、屬性文件、頁面等)時,會重新啟動應用(由于其采用的雙類加載器機制,這個啟動會非???,如果發(fā)現(xiàn)這個啟動比較慢,可以選擇使用jrebel)
雙類加載器機制:boot使用了兩個類加載器來實現(xiàn)重啟(restart)機制:base類加載器(簡稱bc)+restart類加載器(簡稱rc)。
bc:用于加載不會改變的jar(eg.第三方依賴的jar)
rc:用于加載我們正在開發(fā)的jar(eg.整個項目里我們自己編寫的類)。當應用重啟后,原先的rc被丟掉、重新new一個rc來加載這些修改過的東西,而bc卻不需要動一下。這就是devtools重啟速度快的原因。
thymeleaf:boot推薦的模板引擎,這里做簡要的介紹,用來介紹devtools對頁面的熱部署。
項目結(jié)構(gòu):
1、pom.xml
org.springframework.boot spring-boot-starter-thymeleaf org.springframework.boot spring-boot-devtools true
說明:如果僅僅使用thymeleaf,只需要引入thymeleaf;如果需要使用devtools,只需要引入devtools。
注意:
maven中的optional=true表示依賴不會傳遞。即此處引用的devtools不會傳遞到依賴myboot項目的項目中。
僅僅加入devtools在我們的eclipse中還不起作用,這時候還需要對之前添加的spring-boot-maven-plugin做一些修改,如下:
org.springframework.boot spring-boot-maven-plugin true
即添加了fork:true
2、ThymeleafController
package com.xxx.firstboot.web; import org.springframework.stereotype.Controller; import org.springframework.ui.Model; import org.springframework.web.bind.annotation.RequestMapping; import org.springframework.web.bind.annotation.RequestMethod; import org.springframework.web.bind.annotation.RequestParam; import io.swagger.annotations.Api; import io.swagger.annotations.ApiOperation; @Api("測試Thymeleaf和devtools") @Controller @RequestMapping("/thymeleaf") public class ThymeleafController { @ApiOperation("第一個thymeleaf程序") @RequestMapping(value = "/greeting", method = RequestMethod.GET) public String greeting(@RequestParam(name = "name", required = false, defaultValue = "world") String name, Model model) { model.addAttribute("xname", name); return "greet"; } }
說明:Model可以作為一個入?yún)?,在代碼中,將屬性以"key-value"的形式存入model,最后直接返回字符串即可。
3、greet.html
第一個thymeleaf程序 1234567890!!!xx
注意:
src/main/resources/templates:頁面存放目錄
src/main/resources/static:方式靜態(tài)文件(css、js等)
以上的目錄與ssm中開發(fā)的不一樣,ssm中會放在src/main/webapp下
測試:
修改類-->保存:應用會重啟
修改配置文件-->保存:應用會重啟
修改頁面-->保存:應用不會重啟,但會重新加載,頁面會刷新(原理是將spring.thymeleaf.cache設為false)
補充:
默認情況下,/META-INF/maven,/META-INF/resources,/resources,/static,/templates,/public這些文件夾下的文件修改不會使應用重啟,但是會重新加載(devtools內(nèi)嵌了一個LiveReload server,當資源發(fā)生改變時,瀏覽器刷新)。
如果想改變默認的設置,可以自己設置不重啟的目錄:spring.devtools.restart.exclude=static/**,public/**,這樣的話,就只有這兩個目錄下的文件修改不會導致restart操作了。
如果要在保留默認設置的基礎上還要添加其他的排除目錄:spring.devtools.restart.additional-exclude
如果想要使得當非classpath下的文件發(fā)生變化時應用得以重啟,使用:spring.devtools.restart.additional-paths,這樣devtools就會將該目錄列入了監(jiān)聽范圍。