你們可能都據說過開發Node.js應用時可使用多種工具對開發者提供便利,如WebPack提供了開發者服務器來支持js應用動態更替,並在保存文件時自動刷新瀏覽器。Spring Boot也提供了類似的開發者工具,讓咱們更快速、更舒心的開發Spring Boot應用。你們看完本教程就能夠學會如何如用Spring Boot開發者工具進行自動重啓和自動刷新頁面。java
Spring Boot的開發者工具會爲應用建立兩個classloader。一個是用來加載不會變更的類,稱爲base classloader。另外一個是restart classloader,用來加載常常變更的類,默認狀況下Spring Boot開發者工具會監控classpath下全部的類。當有類變更時,舊的restart classloader就會被丟棄,而後再建立一個新的,以此來加快重啓速度。git
Gitee碼雲web
使用IntelliJ建立一個maven項目:spring
使用以下pom.xml
文件配置:apache
<?xml version="1.0" encoding="UTF-8"?> <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd"> <modelVersion>4.0.0</modelVersion> <groupId>cn.zxuqian</groupId> <artifactId>devtools</artifactId> <version>0.0.1-SNAPSHOT</version> <packaging>jar</packaging> <name>devtools</name> <description>Showcase project for Spring Boot developer tools</description> <parent> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-parent</artifactId> <version>2.1.0.BUILD-SNAPSHOT</version> <relativePath/> <!-- lookup parent from repository --> </parent> <properties> <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding> <project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding> <java.version>1.8</java.version> </properties> <dependencies> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-web</artifactId> </dependency> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-devtools</artifactId> <optional>true</optional> </dependency> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-test</artifactId> <scope>test</scope> </dependency> </dependencies> <build> <plugins> <plugin> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-maven-plugin</artifactId> </plugin> </plugins> </build> <repositories> <repository> <id>spring-snapshots</id> <url>https://repo.spring.io/snapshot</url> <snapshots><enabled>true</enabled></snapshots> </repository> <repository> <id>spring-milestones</id> <url>https://repo.spring.io/milestone</url> </repository> </repositories> <pluginRepositories> <pluginRepository> <id>spring-snapshots</id> <url>https://repo.spring.io/snapshot</url> </pluginRepository> <pluginRepository> <id>spring-milestones</id> <url>https://repo.spring.io/milestone</url> </pluginRepository> </pluginRepositories> </project>
這裏咱們用了最新的snapshop版本的spring boot 2.1.0,而後添加spring-boot-devtools
依賴,並把它設置爲optional
的,那麼這樣在最後打包的產品環境中,devtools將不會被打包進來。瀏覽器
接下來添加一個測試用的控制器cn.zxuqian.devtools.controller.HelloController
:服務器
package cn.zxuqian.devtools.controller; import org.springframework.web.bind.annotation.RequestMapping; import org.springframework.web.bind.annotation.RestController; @RestController public class HelloController { @RequestMapping("/") public String hello() { return "hello world"; } }
而後建立cn.zxuqian.devtools.DevtoolsApplication
類配置Spring Boot應用:app
package cn.zxuqian.devtools; import org.springframework.boot.SpringApplication; import org.springframework.boot.autoconfigure.SpringBootApplication; @SpringBootApplication public class DevtoolsApplication { public static void main(String[] args) { SpringApplication.run(DevtoolsApplication.class, args); } }
從LiveReload官網下載LiveReload的Chrome或Firefox或Safari瀏覽器插件,而後啓用此插件。maven
使用spring-boot:run
插件啓動此應用,在瀏覽器打開http://localhost:8080
會看到hello world
字樣。而後在咱們的控制器中把返回值修改一下,如改成:Hola!
,在IntelliJ中,咱們必需要執行Build->Build Project
才能從新編譯新改動的代碼,咱們也能夠用快捷鍵command + (fn) + F9
mac下,來執行編譯。稍等幾秒就會看到瀏覽器自動刷新爲修改後的值了。spring-boot
歡迎訪問個人博客:張旭乾的博客