springboot學習之構建簡單專案搭建
概述
相信對於Java開發者而言,spring和springMvc兩個框架一定不陌生,這兩個框架需要我們手動配置的地方非常多,各種的xml檔案,properties檔案,構建一個專案還是挺複雜的,在這種情況下,springboot應運而生,他能夠快速的構建spring專案,而且讓專案正常執行起來的配置檔案非常少,甚至只需要幾個註解就可以執行整個專案。
總的說來,springboot專案可以打成jar包獨立執行部署,因為它內嵌servlet容器,之前spring,springMvc需要的大量依賴,可以通過starter來幫助我們簡化配置,當然還有其他好多優點,這裡就不一一贅述,小夥伴們可以自行搜尋解答。
簡單專案構建
工具
eclipse maven
首先,我們新建一個maven專案,在eclipse左側右擊選擇new----》other,選擇新建Maven project
輸入group Id,artifact Id,點選完成
這樣一個簡單的專案架子就完成了,但是啥都沒有,專案結構如下圖所示:
下面我們就開始配置搭建springboot專案。
1.新增依賴
完整porm程式碼如下:
1 <project xmlns="http://maven.apache.org/POM/4.0.0" 2xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" 3xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd"> 4<modelVersion>4.0.0</modelVersion> 5 6<groupId>com.cfxmn.springboot</groupId> 7<artifactId>springbootDemo</artifactId> 8<version>0.0.1-SNAPSHOT</version> 9<packaging>jar</packaging> 10 11<!-- 通過繼承spring-boot-starter-parent專案來獲得一些合理的預設配置 --> 12<parent> 13<groupId>org.springframework.boot</groupId> 14<artifactId>spring-boot-starter-parent</artifactId> 15<version>1.5.6.RELEASE</version> 16</parent> 17 18<properties> 19<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding> 20</properties> 21 22<dependencies> 23<!-- Spring Boot Web 依賴 --> 24<dependency> 25<groupId>org.springframework.boot</groupId> 26<artifactId>spring-boot-starter-web</artifactId> 27</dependency> 28 29<!-- Spring Boot Test 依賴 --> 30<dependency> 31<groupId>org.springframework.boot</groupId> 32<artifactId>spring-boot-starter-test</artifactId> 33<scope>test</scope> 34</dependency> 35<!-- 使用Lombok可以減少很多重複程式碼的書寫。比如說getter/setter/toString等方法的編寫 --> 36<dependency> 37<groupId>org.projectlombok</groupId> 38<artifactId>lombok</artifactId> 39</dependency> 40</dependencies> 41 </project> View Code
下面我們新建一些包和新增專案的啟動類,如下圖所示:
其中,控制器DemoController的內容非常簡單,內容如下:
package com.cfxmn.springboot.springbootDemo.controller; import org.springframework.web.bind.annotation.PostMapping; import org.springframework.web.bind.annotation.RestController; import lombok.extern.slf4j.Slf4j; @RestController @Slf4j public class DemoController { @PostMapping("/demo") public void demoTest() { // 這邊簡單起見,列印一下日誌 log.info("success call"); } }
可能有些同學對其中的幾個註解有些疑問,我這邊簡單說明下,
1.RestController
這個註解其實就是@ResponseBody + @Controller
2.PostMapping
這個註解其實就是@RequestMapping("xxxxxx", Method=RequestMethod.POST)
這兩個其實都是組合註解,簡化使用
我們再來看看,專案的啟動類SpringbootDemoApplication的內容:
package com.cfxmn.springboot.springbootDemo; import org.springframework.boot.SpringApplication; import org.springframework.boot.autoconfigure.SpringBootApplication; @SpringBootApplication public class SpringbootDemoApplication { public static void main(String[] args) { SpringApplication.run(SpringbootDemoApplication.class, args); } }
是的,你沒看錯,只要執行這個main方法,就能啟動這個spring專案,具體是怎麼啟動的容器,我們之後再分析,其實主要就是在註解SpringBootApplication上。
下面我們就來執行下,看下啟動日誌:
._______ _ _ /\\ / ___'_ __ _ _(_)_ ____ _ \ \ \ \ ( ( )\___ | '_ | '_| | '_ \/ _` | \ \ \ \ \\/___)| |_)| | | | | || (_| |) ) ) ) '|____| .__|_| |_|_| |_\__, | / / / / =========|_|==============|___/=/_/_/_/ :: Spring Boot ::(v1.5.6.RELEASE) 2018-10-25 23:52:41.985INFO 1700 --- [main] c.c.s.s.SpringbootDemoApplication: Starting SpringbootDemoApplication on DESKTOP-KB78HJK with PID 1700 (E:\workspace\springbootDemo\target\classes started by gepengfa in E:\workspace\springbootDemo) 2018-10-25 23:52:41.990INFO 1700 --- [main] c.c.s.s.SpringbootDemoApplication: No active profile set, falling back to default profiles: default 2018-10-25 23:52:42.088INFO 1700 --- [main] ationConfigEmbeddedWebApplicationContext : Refreshing org.springframework.boot.context.embedded.AnnotationConfigEmbeddedWebApplicationContext@7f416310: startup date [Thu Oct 25 23:52:42 CST 2018]; root of context hierarchy 2018-10-25 23:52:44.561INFO 1700 --- [main] s.b.c.e.t.TomcatEmbeddedServletContainer : Tomcat initialized with port(s): 8080 (http) 2018-10-25 23:52:44.584INFO 1700 --- [main] o.apache.catalina.core.StandardService: Starting service [Tomcat] 2018-10-25 23:52:44.588INFO 1700 --- [main] org.apache.catalina.core.StandardEngine: Starting Servlet Engine: Apache Tomcat/8.5.16 2018-10-25 23:52:44.813INFO 1700 --- [ost-startStop-1] o.a.c.c.C.[Tomcat].[localhost].[/]: Initializing Spring embedded WebApplicationContext 2018-10-25 23:52:44.813INFO 1700 --- [ost-startStop-1] o.s.web.context.ContextLoader: Root WebApplicationContext: initialization completed in 2733 ms 2018-10-25 23:52:45.074INFO 1700 --- [ost-startStop-1] o.s.b.w.servlet.ServletRegistrationBean: Mapping servlet: 'dispatcherServlet' to [/] 2018-10-25 23:52:45.083INFO 1700 --- [ost-startStop-1] o.s.b.w.servlet.FilterRegistrationBean: Mapping filter: 'characterEncodingFilter' to: [/*] 2018-10-25 23:52:45.083INFO 1700 --- [ost-startStop-1] o.s.b.w.servlet.FilterRegistrationBean: Mapping filter: 'hiddenHttpMethodFilter' to: [/*] 2018-10-25 23:52:45.083INFO 1700 --- [ost-startStop-1] o.s.b.w.servlet.FilterRegistrationBean: Mapping filter: 'httpPutFormContentFilter' to: [/*] 2018-10-25 23:52:45.085INFO 1700 --- [ost-startStop-1] o.s.b.w.servlet.FilterRegistrationBean: Mapping filter: 'requestContextFilter' to: [/*] 2018-10-25 23:52:45.582INFO 1700 --- [main] s.w.s.m.m.a.RequestMappingHandlerAdapter : Looking for @ControllerAdvice: org.springframework.boot.context.embedded.AnnotationConfigEmbeddedWebApplicationContext@7f416310: startup date [Thu Oct 25 23:52:42 CST 2018]; root of context hierarchy 2018-10-25 23:52:45.705INFO 1700 --- [main] s.w.s.m.m.a.RequestMappingHandlerMapping : Mapped "{[/demo],methods=[POST]}" onto public void com.cfxmn.springboot.springbootDemo.controller.DemoController.demoTest() 2018-10-25 23:52:45.710INFO 1700 --- [main] s.w.s.m.m.a.RequestMappingHandlerMapping : Mapped "{[/error]}" onto public org.springframework.http.ResponseEntity<java.util.Map<java.lang.String, java.lang.Object>> org.springframework.boot.autoconfigure.web.BasicErrorController.error(javax.servlet.http.HttpServletRequest) 2018-10-25 23:52:45.711INFO 1700 --- [main] s.w.s.m.m.a.RequestMappingHandlerMapping : Mapped "{[/error],produces=[text/html]}" onto public org.springframework.web.servlet.ModelAndView org.springframework.boot.autoconfigure.web.BasicErrorController.errorHtml(javax.servlet.http.HttpServletRequest,javax.servlet.http.HttpServletResponse) 2018-10-25 23:52:45.759INFO 1700 --- [main] o.s.w.s.handler.SimpleUrlHandlerMapping: Mapped URL path [/webjars/**] onto handler of type [class org.springframework.web.servlet.resource.ResourceHttpRequestHandler] 2018-10-25 23:52:45.759INFO 1700 --- [main] o.s.w.s.handler.SimpleUrlHandlerMapping: Mapped URL path [/**] onto handler of type [class org.springframework.web.servlet.resource.ResourceHttpRequestHandler] 2018-10-25 23:52:45.817INFO 1700 --- [main] o.s.w.s.handler.SimpleUrlHandlerMapping: Mapped URL path [/**/favicon.ico] onto handler of type [class org.springframework.web.servlet.resource.ResourceHttpRequestHandler] 2018-10-25 23:52:46.321INFO 1700 --- [main] o.s.j.e.a.AnnotationMBeanExporter: Registering beans for JMX exposure on startup 2018-10-25 23:52:46.529INFO 1700 --- [main] s.b.c.e.t.TomcatEmbeddedServletContainer : Tomcat started on port(s): 8080 (http) 2018-10-25 23:52:46.599INFO 1700 --- [main] c.c.s.s.SpringbootDemoApplication: Started SpringbootDemoApplication in 5.092 seconds (JVM running for 5.764)
從啟動日誌標黃的部分可以看出,專案啟動成功了,訪問埠預設是8080(這個埠是可以改動的)
下面我們通過postMan請求下,
檢視控制檯
2018-10-25 23:59:26.385INFO 1700 --- [nio-8080-exec-2] c.c.s.s.controller.DemoController: success call
說明呼叫成功。
到此,一個簡單的springboot專案就構建完成了,但這只是一個空的架子,內容還可載豐富。
下一篇文章我們主要來分析下,springboot啟動的相關原始碼,敬請期待。