一、创建应用
使用官方Spring Initializr工具生成基础项目(http://start.spring.io/)
导入Intellij idea中
目录结构如下:
二、目录结构说明:
src/main/java:主程序入口Application,可以通过直接运行改类来启动SpringBoot 应用。
src/main/resources:配置目录,该目录用来存放应用的一些配置信息,比如应用名。服务端扣、数据库链接等。由于我们引入了Web模块,因此产生了static目录与template目录,或者用于存放静态资源,比如图片、CSS、JavaScript等;后者用于存放Web页面的模板文件。
src/test/:单元测试目录,生成的ApplicationTests通过JUnit4来实现,可以直接运行Spring Boot应用的测试。
三、Maven配置分析
1 24 4.0.0 5 6com.slp 7springBoot 80.0.1-SNAPSHOT 9jar 10 11springBoot 12Demo project for Spring Boot 13 1415 16 21 22org.springframework.boot 17spring-boot-starter-parent 182.0.3.RELEASE 1920 23 27 28UTF-8 24UTF-8 251.8 2629 42 4330 31 34 35org.springframework.boot 32spring-boot-starter-web 3336 37 41org.springframework.boot 38spring-boot-starter-test 39test 4044 51 52 5345 5046 49org.springframework.boot 47spring-boot-maven-plugin 48
这里所引用的web和test模块,在Spring Boot生态中被称为Starter POMs.Starter POMS是一系列轻便的依赖包,是一套一站式的Spring相关技术的解决方案。
在使用和整合模块时,不需要再去搜寻样例代码中的依赖配置来复制使用,只需要引入对应的模块包即可。比如,开发Web应用的时候,那就再引入spring-boot-starter-web,希望具备数据库能力的时候就引入spring-boot-starter-jdbc,或者更好用的spring-boot-starter-data-jpa,在使用Spring Boot构建应用的时候,各项功能模块的整合不像传统Spring应用的开发方式那样,需要在pom.xml中做大量的依赖配置。而是通过Starter POMs定义的依赖包,使得功能整合变得非常轻巧,易于使用。
Spring Boot的Starter POMs采用spring-boot-starter-*的命名方式,*代表一个特别的应用功能模块,比如web test。Spring Boot工程本身的结构非常简单,大量的学习要点还是将来在对这些Starter POMs的使用之上。
项目构建的build部分,引入了SpringBoot的Maven插件,该插件非常实用,可以帮助我们更方便的启停应用,这样在开发时就不用每次去找主类火灾打包成ja来运行微服务,只需要mvn spring-boot:run命令就可以启动。
四、实现RESTful API
1 package com.slp.web; 2 3 import org.springframework.web.bind.annotation.RequestMapping; 4 import org.springframework.web.bind.annotation.RestController; 5 6 /** 7 * @author sanglp 8 * @create 2018-06-28 8:39 9 * @desc 第一个 controller10 **/11 12 @RestController13 public class HelloController {14 @RequestMapping("/hello")15 public String index(){16 return "Hello World";17 }18 }
五。启动Spring Boot应用
1、作为一个Java应用程序,可以直接通过运行拥有main函数的类来启动
2、在Maven配置中,之前提到了spring-boot插件。可以使用它来启动,比如执行mvn spring-boot:run命令,或是直接单击IDE中对Maven插件的工具,例如Intellij中的支持
3、在服务器上部署时,通常先使用mvn install将应用打包成jar包,再通过java -jar xxx.jar来启动应用。
六、编写单元测试
package com.slp.springBoot;import com.slp.web.HelloController;import org.junit.Before;import org.junit.Test;import org.junit.runner.RunWith;import org.springframework.boot.test.context.SpringBootTest;import org.springframework.http.MediaType;import org.springframework.test.context.junit4.SpringJUnit4ClassRunner;import org.springframework.test.context.web.WebAppConfiguration;import org.springframework.test.web.servlet.MockMvc;import org.springframework.test.web.servlet.request.MockMvcRequestBuilders;import org.springframework.test.web.servlet.setup.MockMvcBuilders;import static org.hamcrest.Matchers.equalTo;import static org.springframework.test.web.servlet.result.MockMvcResultMatchers.content;import static org.springframework.test.web.servlet.result.MockMvcResultMatchers.status;//@RunWith(SpringRunner.class)@RunWith(SpringJUnit4ClassRunner.class)@SpringBootTest@WebAppConfigurationpublic class ApplicationTests { //模拟调用Controller的接口发起请求,在@Test定义的hello测试用例中,perform函数执行一次请求调用,accept用于执行接收的数据类型,ansExpect用于判断接口返回的期望值 private MockMvc mvc; //JUnit中定义在测试用例@Test内容执行前预加载的内容,这里用来初始化HelloController的模拟 @Before public void setUp() throws Exception{ mvc = MockMvcBuilders.standaloneSetup(new HelloController()).build(); } @Test public void contextLoads() { } @Test public void hello()throws Exception{ mvc.perform(MockMvcRequestBuilders.get("/hello").accept(MediaType.APPLICATION_JSON)) .andExpect(status().isOk()).andExpect(content().string(equalTo("Hello World"))); }}